GNU Info

Info Node: (cpp-300.info)Once-Only Headers

(cpp-300.info)Once-Only Headers


Next: Computed Includes Prev: Search Path Up: Header Files
Enter node , (file) or (file)node

Once-Only Headers
=================

   If a header file happens to be included twice, the compiler will
process its contents twice.  This is very likely to cause an error,
e.g. when the compiler sees the same structure definition twice.  Even
if it does not, it will certainly waste time.

   The standard way to prevent this is to enclose the entire real
contents of the file in a conditional, like this:

     /* File foo.  */
     #ifndef FILE_FOO_SEEN
     #define FILE_FOO_SEEN
     
     THE ENTIRE FILE
     
     #endif /* !FILE_FOO_SEEN */

   This construct is commonly known as a "wrapper #ifndef".  When the
header is included again, the conditional will be false, because
`FILE_FOO_SEEN' is defined.  The preprocessor will skip over the entire
contents of the file, and the compiler will not see it twice.

   GNU CPP optimizes even further.  It remembers when a header file has
a wrapper `#ifndef'.  If a subsequent `#include' specifies that header,
and the macro in the `#ifndef' is still defined, it does not bother to
rescan the file at all.

   You can put comments outside the wrapper.  They will not interfere
with this optimization.

   The macro `FILE_FOO_SEEN' is called the "controlling macro" or
"guard macro".  In a user header file, the macro name should not begin
with `_'.  In a system header file, it should begin with `__' to avoid
conflicts with user programs.  In any kind of header file, the macro
name should contain the name of the file and some additional text, to
avoid conflicts with other header files.


automatically generated by info2www version 1.2.2.9