⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 directives-within-macro-arguments.html

📁 gcc手册
💻 HTML
字号:
<html lang="en">

<head>

<title>The C Preprocessor</title>

<meta http-equiv="Content-Type" content="text/html">

<meta name="description" content="The C Preprocessor">

<meta name="generator" content="makeinfo 4.3">

<link href="http://www.gnu.org/software/texinfo/" rel="generator-home">

<!--

Copyright &copy; 1987, 1989, 1991, 1992, 1993, 1994, 1995, 1996,

1997, 1998, 1999, 2000, 2001, 2002, 2003

Free Software Foundation, Inc.



   <p>Permission is granted to copy, distribute and/or modify this document

under the terms of the GNU Free Documentation License, Version 1.1 or

any later version published by the Free Software Foundation.  A copy of

the license is included in the

section entitled "GNU Free Documentation License".



   <p>This manual contains no Invariant Sections.  The Front-Cover Texts are

(a) (see below), and the Back-Cover Texts are (b) (see below).



   <p>(a) The FSF's Front-Cover Text is:



   <p>A GNU Manual



   <p>(b) The FSF's Back-Cover Text is:



   <p>You have freedom to copy and modify this GNU Manual, like GNU

     software.  Copies published by the Free Software Foundation raise

     funds for GNU development. 

-->

</head>

<body>

<div class="node">

<p>

Node:<a name="Directives%20Within%20Macro%20Arguments">Directives Within Macro Arguments</a>,

Next:<a rel="next" accesskey="n" href="Macro-Pitfalls.html#Macro%20Pitfalls">Macro Pitfalls</a>,

Previous:<a rel="previous" accesskey="p" href="Undefining-and-Redefining-Macros.html#Undefining%20and%20Redefining%20Macros">Undefining and Redefining Macros</a>,

Up:<a rel="up" accesskey="u" href="Macros.html#Macros">Macros</a>

<hr><br>

</div>



<h3 class="section">Directives Within Macro Arguments</h3>



   <p>Occasionally it is convenient to use preprocessor directives within

the arguments of a macro.  The C and C++ standards declare that

behavior in these cases is undefined.



   <p>Versions of CPP prior to 3.2 would reject such constructs with an

error message.  This was the only syntactic difference between normal

functions and function-like macros, so it seemed attractive to remove

this limitation, and people would often be surprised that they could

not use macros in this way.  Moreover, sometimes people would use

conditional compilation in the argument list to a normal library

function like <code>printf</code>, only to find that after a library upgrade

<code>printf</code> had changed to be a function-like macro, and their code

would no longer compile.  So from version 3.2 we changed CPP to

successfully process arbitrary directives within macro arguments in

exactly the same way as it would have processed the directive were the

function-like macro invocation not present.



   <p>If, within a macro invocation, that macro is redefined, then the new

definition takes effect in time for argument pre-expansion, but the

original definition is still used for argument replacement.  Here is a

pathological example:



<pre class="smallexample">     #define f(x) x x

     f (1

     #undef f

     #define f 2

     f)

     </pre>



<p>which expands to



<pre class="smallexample">     1 2 1 2

     </pre>



<p>with the semantics described above.



   </body></html>



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -