> 文档中心 > C语言预编译时,去注释和宏替换是谁先进行呢?

C语言预编译时,去注释和宏替换是谁先进行呢?

今天我们重点讲下define定义的常量,define定义注释和程序的翻译过程。

今天要心情愉悦,开心的学习。
在这里插入图片描述

1.define定义数值宏常量

#define它可以出现在代码的任何地方,从本行宏定义开始,以后的代码就就都认识这个宏了,也可以把任何东西定义成宏。那么在定义宏之前的代码可以认出来它吗?

看个例子:

void test(){printf("%d\n", NUM);}#define NUM 10int main(){test();printf("%d\n", NUM);return 0;}

首先宏可以在任何位置,但是,它是在test函数之后定义的,所以函数内部是不会认同这个宏,也就不会发生替换。
在这里插入图片描述
这里看出了,第一个NUM没有被替换,而#define NUM 10直接变成空格,第二个NUN直接被替换了。

那么为什么要用宏定义的数字常量呢?
比如,你要使用 π ,但是突然就定义了,一个浮点数进行赋值,会有些突兀,这种数字被称为 “ 魔术数字”,不知道原因,这就很令人抓狂。

另外,再说下宏定义的常量,它只会简单的替换,没有数据类型这一说。

2.#define定义字符串

一般来说吗,定义宏定义的字符串,常用于定义一个文件路径,要用双引号引起来字符串。
看个例子:

#define ENG_PATH_1 "D\\CSDN\\\csdn_4_9\\胡杨\\树下"int main(){int a = 0;printf("%s\n", ENG_PATH_1);return 0;}

在这里插入图片描述
分析一下,首先路径是 \ 分割开的,打印时需要进行转义,用 \\ 来进行转义,但是如果路径太长那么,那么需要分割时,用续行符 \ 进行换行。所以就有了三个\\\的情况。

3.用#define定义的宏进行替换注释。

说到这个话题就要简单谈下预处理了
现在有一个文本式的代码需要变成可执行程序要怎么办呢?
首先要进行 预处理 编译 汇编 链接 最后形成一个可执行程序。下面就说下每个过程的操作。

预处理::头文件展开,去注释,宏替换,条件编译。
编译:把C文件转化为二进制文件。
汇编:将汇编语言转化为成为可重定向目标文件(简单说就是可以被链接)
链接:将自身程序和库文件形成关联,形成可执行程序。

预编译

预处理的头文件展开很好理解,就是把头文件内容进行展开
看个例子 :
没有头文件时

#define MAX 20int main(){int a = MAX;++return 0;}++

在这里插入图片描述这个预处理后的.i文件内容很短。加上头文件后就变很长了在这里插入图片描述

这就是把头文件展开了。

去注释和宏替换:

去注释和宏替换是谁先执行呢?
看个例子 :
在这里插入图片描述
如果是先进行宏替换,在进行去注释的话,那么int a = 10,这条语句会被注释,变成空格,从这里看的出来,那就是先去注释,再进行宏替换了,所以就变成了#define MAX " " ,然后再进行宏替换成了空格。

这里还有一个更直观的例子,用宏定义C语言风格的注释。
看个例子 :
在这里插入图片描述
这里的是直接把宏 MIN 都注释掉了,宏 MAX 的内容为0, 所以这里会有一个MIN没有被替换,这也更加说明是先进行的去注释,在进行的宏替换。

下期预告:

下期会讲宏相关的更多的知识。
下期更精彩~~~

在这里插入图片描述