预处理过程扫描源代码,对其进行初步的转换,产生新的源代码提供给编译器。可见
预处理过程先于编译器对源代码进行处理。
在 C 语言中,并没有任何内在的机制来完成如下一些功能:在编译时包含其他源文
件、定义宏、根据条件决定编译时是否包含某些代码。要完成这些工作,就需要使用预处理
程序。尽管在目前绝大多数编译器都包含了预处理程序,但通常认为它们是独立于编译器
的。预处理过程读入源代码,检查包含预处理指令的语句和宏定义,并对源代码进行响应
的转换。预处理过程还会删除程序中的注释和多余的空白字符。
预处理指令是以#号开头的代码行。#号必须是该行除了任何空白字符外的第一个字符。
#后是指令关键字,在关键字和#号之间允许存在任意个数的空白字符。整行语句构成了一
条预处理指令,该指令将在编译器进行编译之前对源代码做某些转换。下面是部分预处理
指令:
指令用途
#空指令,无任何效果
#include 包含一个源代码文件
#define 定义宏
#undef 取消已定义的宏
#if 如果给定条件为真,则编译下面代码
#ifdef 如果宏已经定义,则编译下面代码
#ifndef 如果宏没有定义,则编译下面代码
#elif 如果前面的#if 给定条件不为真,当前条件为真,则编译下面代码
#endif 结束一个#if……#else 条件编译块
#error 停止编译并显示错误信息
一、文件包含
#include 预处理指令的作用是在指令处展开被包含的文件。包含可以是多重的,也就是说
一个被包含的文件中还可以包含其他文件。标准 C 编译器至少支持八重嵌套包含。
预处理过程不检查在转换单元中是否已经包含了某个文件并阻止对它的多次包含。这