编译预处理
专题三:编译预处理。包括以下章节:
- 编译过程简介
- 宏定义与宏使用分析
- 条件编译使用分析
- #error和#line
- #pragma预处理分析
- #和##运算符使用解析
#error用法
- #error用于生成一个编译错误消息,并停止编译
- 用法:#error message(message不需要使用双引号)
- #weaning用于生成一个编译警告信息,不会停止编译
- 用法:#weaning message(message不需要使用双引号)
实例分析4-1
4-1.c
#include <stdio.h>
#define CONST_NAME1 "CONST_NAME1"
#define CONST_NAME2 "CONST_NAME2"
int main()
{
#ifndef COMMAND
#warning Compilation will be stoped ...
#error No defined Constant Symbol COMMAND
#endif
printf("%s\n", COMMAND);
printf("%s\n", CONST_NAME1);
printf("%s\n", CONST_NAME2);
return 0;
}
结果:
#line用法
- #line用于强制指定新的行号和编译文件名,并对源程序的代码重新编号
- #line编译指示字的本质是重定义_LINE_和_FILE_
- 用法: #line number filename(filename可省略)
实例分析4-2
4-2.c
#include <stdio.h>
#define CONST_NAME1 "CONST_NAME1"
#define CONST_NAME2 "CONST_NAME2"
int f();
int main()
{
printf("%s\n", CONST_NAME1);
printf("%s\n", CONST_NAME2);
printf("%d\n", __LINE__);
printf("%s\n", __FILE__);
f();
return 0;
}
//作用:一个文件可能由不同的程序员完成。不同程序员可以定义不同的行,不同的文件名,便于找到谁写的代码,多少行出错
#line 1 "Hello.c"
int f()
{
a+b,
}
结果:
3万+

被折叠的 条评论
为什么被折叠?



