| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
 | <div class="section-level-extent" id="Precompiled-Headers"> <div class="nav-panel"> <p> Next: <a href="c_002b_002b-modules" accesskey="n" rel="next">C++ Modules</a>, Previous: <a href="environment-variables" accesskey="p" rel="prev">Environment Variables Affecting GCC</a>, Up: <a href="invoking-gcc" accesskey="u" rel="up">GCC Command Options</a> [<a href="index#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="indices" title="Index" rel="index">Index</a>]</p> </div>  <h1 class="section" id="Using-Precompiled-Headers"><span>3.22 Using Precompiled Headers<a class="copiable-link" href="#Using-Precompiled-Headers"> ¶</a></span></h1>   <p>Often large projects have many header files that are included in every source file. The time the compiler takes to process these header files over and over again can account for nearly all of the time required to build the project. To make builds faster, GCC allows you to <em class="dfn">precompile</em> a header file. </p> <p>To create a precompiled header file, simply compile it as you would any other file, if necessary using the <samp class="option">-x</samp> option to make the driver treat it as a C or C++ header file. You may want to use a tool like <code class="command">make</code> to keep the precompiled header up-to-date when the headers it contains change. </p> <p>A precompiled header file is searched for when <code class="code">#include</code> is seen in the compilation. As it searches for the included file (see <a data-manual="cpp" href="https://gcc.gnu.org/onlinedocs/cpp/Search-Path.html#Search-Path">Search Path</a> in The C Preprocessor) the compiler looks for a precompiled header in each directory just before it looks for the include file in that directory. The name searched for is the name specified in the <code class="code">#include</code> with ‘<samp class="samp">.gch</samp>’ appended. If the precompiled header file cannot be used, it is ignored. </p> <p>For instance, if you have <code class="code">#include "all.h"</code>, and you have <samp class="file">all.h.gch</samp> in the same directory as <samp class="file">all.h</samp>, then the precompiled header file is used if possible, and the original header is used otherwise. </p> <p>Alternatively, you might decide to put the precompiled header file in a directory and use <samp class="option">-I</samp> to ensure that directory is searched before (or instead of) the directory containing the original header. Then, if you want to check that the precompiled header file is always used, you can put a file of the same name as the original header in this directory containing an <code class="code">#error</code> command. </p> <p>This also works with <samp class="option">-include</samp>. So yet another way to use precompiled headers, good for projects not designed with precompiled header files in mind, is to simply take most of the header files used by a project, include them from another header file, precompile that header file, and <samp class="option">-include</samp> the precompiled header. If the header files have guards against multiple inclusion, they are skipped because they’ve already been included (in the precompiled header). </p> <p>If you need to precompile the same header file for different languages, targets, or compiler options, you can instead make a <em class="emph">directory</em> named like <samp class="file">all.h.gch</samp>, and put each precompiled header in the directory, perhaps using <samp class="option">-o</samp>. It doesn’t matter what you call the files in the directory; every precompiled header in the directory is considered. The first precompiled header encountered in the directory that is valid for this compilation is used; they’re searched in no particular order. </p> <p>There are many other possibilities, limited only by your imagination, good sense, and the constraints of your build system. </p> <p>A precompiled header file can be used only when these conditions apply: </p> <ul class="itemize mark-bullet"> <li>Only one precompiled header can be used in a particular compilation. </li>
<li>A precompiled header cannot be used once the first C token is seen. You can have preprocessor directives before a precompiled header; you cannot include a precompiled header from inside another header. </li>
<li>The precompiled header file must be produced for the same language as the current compilation. You cannot use a C precompiled header for a C++ compilation. </li>
<li>The precompiled header file must have been produced by the same compiler binary as the current compilation is using. </li>
<li>Any macros defined before the precompiled header is included must either be defined in the same way as when the precompiled header was generated, or must not affect the precompiled header, which usually means that they don’t appear in the precompiled header at all. <p>The <samp class="option">-D</samp> option is one way to define a macro before a precompiled header is included; using a <code class="code">#define</code> can also do it. There are also some options that define macros implicitly, like <samp class="option">-O</samp> and <samp class="option">-Wdeprecated</samp>; the same rule applies to macros defined this way. </p> </li>
<li>If debugging information is output when using the precompiled header, using <samp class="option">-g</samp> or similar, the same kind of debugging information must have been output when building the precompiled header. However, a precompiled header built using <samp class="option">-g</samp> can be used in a compilation when no debugging information is being output. </li>
<li>The same <samp class="option">-m</samp> options must generally be used when building and using the precompiled header. See <a class="xref" href="submodel-options">Machine-Dependent Options</a>, for any cases where this rule is relaxed. </li>
<li>Each of the following options must be the same when building and using the precompiled header: <div class="example smallexample"> <pre class="example-preformatted" data-language="cpp">-fexceptions</pre>
</div> </li>
<li>Some other command-line options starting with <samp class="option">-f</samp>, <samp class="option">-p</samp>, or <samp class="option">-O</samp> must be defined in the same way as when the precompiled header was generated. At present, it’s not clear which options are safe to change and which are not; the safest choice is to use exactly the same options when generating and using the precompiled header. The following are known to be safe: <div class="example smallexample"> <pre class="example-preformatted" data-language="cpp">-fmessage-length=  -fpreprocessed  -fsched-interblock
-fsched-spec  -fsched-spec-load  -fsched-spec-load-dangerous
-fsched-verbose=<var class="var">number</var>  -fschedule-insns  -fvisibility=
-pedantic-errors</pre>
</div> </li>
<li>Address space layout randomization (ASLR) can lead to not binary identical PCH files. If you rely on stable PCH file contents disable ASLR when generating PCH files. </li>
</ul> <p>For all of these except the last, the compiler automatically ignores the precompiled header if the conditions aren’t met. If you find an option combination that doesn’t work and doesn’t cause the precompiled header to be ignored, please consider filing a bug report, see <a class="ref" href="https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/Bugs.html">Reporting Bugs</a>. </p> <p>If you do use differing options when generating and using the precompiled header, the actual behavior is a mixture of the behavior for the options. For instance, if you use <samp class="option">-g</samp> to generate the precompiled header but not when using it, you may or may not get debugging information for routines in the precompiled header. </p> </div>  <div class="nav-panel"> <p> Next: <a href="c_002b_002b-modules">C++ Modules</a>, Previous: <a href="environment-variables">Environment Variables Affecting GCC</a>, Up: <a href="invoking-gcc">GCC Command Options</a> [<a href="index#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="indices" title="Index" rel="index">Index</a>]</p> </div><div class="_attribution">
  <p class="_attribution-p">
    © Free Software Foundation<br>Licensed under the GNU Free Documentation License, Version 1.3.<br>
    <a href="https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/Precompiled-Headers.html" class="_attribution-link">https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/Precompiled-Headers.html</a>
  </p>
</div>
 |