预编译之__LINE__和__FILE__宏

来源:互联网 发布:nginx imagefilter 编辑:程序博客网 时间:2024/03/28 19:31

       在提示出错信息和进行错误处理方面,除了assert断言外,C标准还定义了2个宏:__LINE__和__FILE__。它们在许多执行出错的场合下都很有用处。例如,可以把它们和assert联用来更精确地定位导致assert失败的出错点。实际上,大多数assert实现都使用了__LINE__和__FILE__来完成它们的工作。下面举个例子来说明这两个宏的用处:

先定义一个打开文件的模块,包含头文件filefcn.h和执行文件filefcn.c



我们在编写一个测试函数测试一下:


因为涉及到多个文件,我们用make工具的话,需要写个Makefile文件


生成可执行BIN文件testmacs


执行后的结果为:

[testmacs.c:21] open_file() failed


首先在filefcn.c的open_file函数中,line和file分别是__LINE__和__FILE__的占位符,这两个宏是由调用函数传入。在编译之前预处理器把__LINE__分别换成13和21,把__FILE__换成源代码文件的名字testmacs.c。如果open_file函数调用成功,则它返回0,否则它向stderr打印出诊断信息,指出它失败并返回1的文件名和行号(调用它的函数里的行号)。如果我们在open_file的定义中使用__LINE__和__FILE__,行号和文件名就用处不大了。

从运行的结果可以看到在testmacs.c的第21行执行失败,因为目录下没有tab_baz这个文件。__FILE__和__LINE__在跟踪程序错误方面也很有用。

1 0