1.#error的用法
#error用于生成一个编译错误消息
用法:#error message,其中message不需要用双引号包围
#error编译指示字用于自定义程序员特有的编译错误消息,类似的,#warning用于生成编译警告
#error是一种预编译器指示字
#error可用于提示编译条件是否满足
编译过程中的任意错误信息意味着无法生成最终的可执行程序。
2.编程实验
#error预处理初探
#include <stdio.h>
//#ifndef __cplusplus
//#error This file should be processed with C++ compiler.
//#endif
class CppClass
{
private:
int m_value;
public:
CppClass()
{
}
~CppClass()
{
}
};
int main()
{
return 0;
}
先注释掉3-5行的代码,使用gcc编译结果如下:
当出现这样的编译错误后不一定是我们的代码错了,可能是我们的编译器用错了。比如我们使用了开源代码或者第三方库经常会出现这样的错误。这样的错误我们不好定位,甚至看不懂这样的错误信息,这时我们只需要加上第3-5行的代码,然后再进行编译。加上3-5行的程序后,gcc编译结果如下:
3.编程实验
#error在条件编译中的应用
#include <stdio.h>
void f()
{
#if ( PRODUCT == 1 )
printf(“This is a low level product!\n”);
#elif ( PRODUCT == 2 )
printf(“This is a middle level product!\n”);
#elif ( PRODUCT == 3 )
printf(“This is a high level product!\n”);
#endif
}
int main()
{
f();
printf("1. Query Information.\n");
printf("2. Record Information.\n");
printf("3. Delete Information.\n");
#if ( PRODUCT == 1 )
printf(“4. Exit.\n”);
#elif ( PRODUCT == 2 )
printf(“4. High Level Query.\n”);
printf(“5. Exit.\n”);
#elif ( PRODUCT == 3 )
printf(“4. High Level Query.\n”);
printf(“5. Mannul Service.\n”);
printf(“6. Exit.\n”);
#endif
return 0;
}
我们在编译的时候如果忘记了定义PRODUCT宏,也可以编译通过,但运行结果不是我们想要的,我们希望在没有定义PRODUCT宏的时候,程序编译报错。
我们修改程序,加入#error编译错误信息:
#include <stdio.h>
void f()
{
#if ( PRODUCT == 1 )
printf(“This is a low level product!\n”);
#elif ( PRODUCT == 2 )
printf(“This is a middle level product!\n”);
#elif ( PRODUCT == 3 )
printf(“This is a high level product!\n”);
#else
#error The “PRODUCT” is NOT defined!
#endif
}
int main()
{
f();
printf("1. Query Information.\n");
printf("2. Record Information.\n");
printf("3. Delete Information.\n");
#if ( PRODUCT == 1 )
printf(“4. Exit.\n”);
#elif ( PRODUCT == 2 )
printf(“4. High Level Query.\n”);
printf(“5. Exit.\n”);
#elif ( PRODUCT == 3 )
printf(“4. High Level Query.\n”);
printf(“5. Mannul Service.\n”);
printf(“6. Exit.\n”);
#else
#error The “PRODUCT” is NOT defined!
#endif
return 0;
}
当我们不定义PRODUCT宏直接编译时,结果如下:
这正是我们想要的结果。
4. #line的用法
#line用于强制指定新的行号和编译文件名,并对源程序的代码重新编号
用法#line number filename:其中filename可省略
#line编译指示字的本质是重新定义__LINE__和__FILE__
#line在现代编译器中基本不再使用了
以前的程序由多人开发,而且都写在一个文件中,出现编译错误时不知道是谁的程序出错了,所以引入了#line。
5. 小结
#error用于自定义一条编译错误信息
#warning用于自定义一条编译警告信息
#error和#warning常用于条件编译的情形
#line用于强制指定新的行号和编译文件名
————————————————
版权声明:本文为CSDN博主「小虾米_2018」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_22847457/article/details/98937759