第23课 #error 和 #line 使用分析

1. #error的用法

(1)#error是一种预编译器指示字,用于生成一个编译错误消息

(2)用法:#error message  //注意:message不需要用双引号包围

(3)#error编译指示字用于自定义程序员特有的编译错误消息。类似的,#warning用于生成编译警告错误。

(4)#error可用于提示编译条件是否满足。编译过程中的任何错误意味着无法生成最终的可执行程序。

【实例分析】#error预处理初探

//#include <stdio.h>

//因定义了类,所以该文件只能用C++编译器,而不能用C编译器编译
//C++命令行:g++ 23-1.c;
//C命令行编译:gcc 23-1.c, 但会出现#error指示的错误!
#ifndef __cplusplus
    #error This file should be processed with C++ compiler
#endif

class CppClass
{
private:
    int m_nValue;
public:
    CppClass(){};
    ~CppClass(){};
};

int main()
{
    return 0;
}

【编程实验】#error在条件编译中的应用

#include <stdio.h>

//编译以下文件时,可测试PRODUCT未定义和定义两种不同情况
//带定义宏的编译命令行:gcc -DPRODUCT=3 23-2.c或gcc 23-2.c -DPRODUCT=3
//不带宏的编译命令行:  gcc 23-2.c -o
void f()
{
#if (PRODUCT == 1)
    printf("This is a low level product!\n");
#elif (PROUDCT == 2)
    printf("This is a middle level product!\n");
#elif (PRODUCT == 3)
    printf("This is a high level product!\n");
#else
    #error The PRODUCT macro is NOT defined! //未定义PRODUCT宏时
#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. Mannual Service.\n");
    printf("6. Exit.\n");
#else
    #error The PRODUCT macro is NOT defined! //未定义PRODUCT宏时
#endif

    return 0;
}

2. #line的用法

(1)#line用于强制指定新的行号和编译文件名,并对源程序的代码重新编号

(2)用法:#line number newFilename //newFilename可省略

(3)#line编译指示字的本质是重定义__LINE__和__FILE__

【编程实验】#line的使用

#include <stdio.h>

//作者A写的代码
//--------------------------开始--------------------------
//把line的下一行定义为第1行,文件名为“a.c”
#line 1 "a.c"

//--------------------------结束--------------------------

//作者B写的代码
//--------------------------开始--------------------------
//把line的下一行定义为第1行,文件名为“b.c”
#line 1 "b.c"

//--------------------------结束--------------------------

//作者C写的代码
//--------------------------开始--------------------------
#line 1 "MyCode.c"

int main()
{
    printf("%s:%d\n",__FILE__,__LINE__);//输出MyCode.c:4

    #line 1 "Test.c"
    printf("%s:%d\n",__FILE__,__LINE__);//输出Test.c:1

    return 0;
}
//--------------------------结束--------------------------

3. 小结

(1)#error用于自定义一条编译错误信息

(2)#warnin用于自定义一条编译警告信息

(3)#error和#warning常应用于条件编译的情形

(4)#line用于强制指定新的行号编译文件名

时间: 2024-10-08 13:53:11

第23课 #error 和 #line 使用分析的相关文章

第23课 #error和#line使用分析

#error的用法: 示例程序: 1 #include <stdio.h> 2 3 #ifndef __cplusplus 4 #error This file should be processed with C++ compiler. 5 #endif 6 7 class CppClass 8 { 9 private: 10 int m_value; 11 public: 12 CppClass() 13 { 14 15 } 16 17 ~CppClass() 18 { 19 } 20 }

#error和#line使用分析

#error的用法 #error用于生成一个编译错误消息 用法:error message(不需要用双引号包围) #error编译指示字用于自定义程序员特有的编译错误,消息类似的 #warning用于生成编译警告 #error是一种预编译器指示字 #error可用于提示编译条件是否满足 编译过程中的任意错误信息意味着无法生成最终的可执行程序 例子1:#error预处理初探 #include<stdio.h> #ifndef __cplusplus #error This file should

第3课 - 进化后的const分析

第3课 - 进化后的const分析 1. C语言中的const (1)const 修饰的变量具有只读属性,本质还是变量,只是告诉编译器该变量不能出现在赋值符号的左边. (2)const 修饰的局部变量在栈上分配空间,修饰的全局变量在只读存储区分配空间. (3)const 只在编译期间有用,在运行期间无用.const 不能定义真正意义上的常量(const英文含义)! (4)C语言中的常量只有枚举这一种类型. 2. C++中的const C++ 在 C 的基础上对 const 进行了进化处理. (1

mysql导入时出现&quot;ERROR at line : Unknown command &#39;\&#39;&#39;.&quot;的解决办法

使用mysqldump -uroot -p123456 databases > /home/databases.sql 进行备份 在使用mysql -uroot -p123456 databases  < /home/databases.sql 进行mysql恢复的时候,出现如下报错. ERROR at line 79: Unknown command '\0'. 上述错误,是因为导出时字符集的问题,解决方法如下:--default-character-set=utf8 在导入时加上mysql

Parse Fatal Error at line 41 column 24: 元素类型 &quot;url-pattern&quot; 必须由匹配的结束标记 &quot;&lt;/url-pattern&gt;&quot; 终止

1.错误描述 严重: Parse Fatal Error at line 41 column 24: 元素类型 "url-pattern" 必须由匹配的结束标记 "</url-pattern>" 终止. org.xml.sax.SAXParseException; systemId: jndi:/localhost/SpringMVCH/WEB-INF/web.xml; lineNumber: 41; columnNumber: 24; 元素类型 &qu

Internal error: (org.jdom.input.JDOMParseException) Error on line 1: 文件提前结束。

环境: maven idea tomcat 异常描述: maven clean ,install都没问题,就是点击启动tomcat,时就报错,错误信息如下: Internal error: (org.jdom.input.JDOMParseException) Error on line 1: 文件提前结束.org.jdom.input.JDOMParseException: Error on line 1: 文件提前结束. at org.jdom.input.SAXBuilder.build(

intellij (org.jdom.input.JDOMParseException) Error on line 1: 前言中不允许有内容。

今天打开前几天做的一个项目,发现运行后竟然出现 Error:Internal error: (org.jdom.input.JDOMParseException) Error on line 1: 前言中不允许有内容.org.jdom.input.JDOMParseException: Error on line 1: 前言中不允许有内容. at org.jdom.input.SAXBuilder.build(SAXBuilder.java:533) at org.jdom.input.SAXB

Git使用之搭建基于SSH的Git服务器(中篇) -- fatal protocol error bad line length character: micr

在连接Git服务器的过程中,可能出现fatal protocol error bad line length character: micr的错误.原因是Git服务器搭建时,选择错误的协议了,不要选Windows Shell,选择Linux shell and Sftp即可.

&quot;fatal: protocol error: bad line length character: No This&quot;

git clone 远程地址时候出现 "fatal: protocol error: bad line length character: No This" 错误 在stackoverflow上查到的是修改~/.bashrc文件采用 echo "错误信息" 1&2>/dev/null 来忽略错误提示 我出现这种问题的原因是: /etc/passwd文件里面 git:x:501:502::/home/git:/sbin/nologin 修改成为 git: