C语言中的__FILE__、__LINE__和__func__等预定义跟踪调试【转】

 

(转自:https://blog.csdn.net/qq_33706673/article/details/78628202)

C语言中的__FILE__、__LINE__和__DATE__等都在头文件#include

如果编译器不是标准的,则可能仅支持以上宏名中的几个,或根本不支持。记住编译程序也许还提供其它预定义的宏名。
__LINE__ 及 __FILE__ 宏指示,#line指令可以改变它的值,简单的讲,编译时,它们包含程序的当前行数和文件名。
__STDC__ 宏指令的意义是编译时定义的。一般来讲,如果__STDC__已经定义,编译器将仅接受不包含任何非标准扩展的标准C/C++代码。如果实现是标准的,则宏__STDC__含有十进制常量1。如果它含有任何其它数,则实现是非标准的。
__cplusplus 与标准c++一致的编译器把它定义为一个包含至少6为的数值。与标准c++不一致的编译器将使用具有5位或更少的数值。


常用宏的具体例子如下:

C语言中的__LINE__用以指示本行语句在源文件中的位置信息,举例如下:

#include 

main()
{
printf("%d\n",__LINE__);
printf("%d\n",__LINE__);
printf("%d\n",__LINE__);
};


该程序在linux用gcc编译,在windows的VS2013下编译都可以通过,执行结果都为:
7

8

9
还可以通过语句#line来重新设定__LINE__的值,举例如下:

#include 


#line 200  //指定下一行的__LINE__为200
main()
{
printf("%d\n",__LINE__);
printf("%d\n",__LINE__);
printf("%d\n",__LINE__);
};


编译执行后输出结果为:
202
203
204


C语言中的__FILE__用以指示本行语句所在源文件的文件。

 

#include 
int main()
{
printf("%s\n",__FILE__);
}


在gcc编译生成a.out,执行后输出结果为:
test.c
在windows的VS2013下编译执行结果为:
d:\work\c&c++\project\project1\project1\main.cpp
--------------------------------------------------------------------------------------------------------------------------------------------------
C语言中__DATE__和__TIME__表示时间和日期

#include
void main(void)
{
    printf("%s\n",__DATE__);
    printf("%s\n",__TIME__);
    getch();
}


结果:
Nov 24 2017
21:15:27

__STDC__是预定义宏。当它被定义后,编译器将按照ansic标准来编译你的c程序。
__cplusplus用来定义是否是C++编译器

#include 
int main(void)
{
 #ifdef _cplusplus
  printf("C++\n");
 #endif
 
 #ifdef __STDC__
  printf("C\n");
 #endif
 return 0;
}


输出结果为:
C
但是如果在前面定义_cplusplus

#include 
#define _cplusplus
int main(void)
{
 #ifdef _cplusplus
  printf("C++\n");
 #endif
 
 #ifdef __STDC__
  printf("C\n");
 #endif
 return 0;
}


那么输出就是:
C++
C

另外gcc还支持__func__,和__FUNCTION__,它指示所在的函数,但是这个关键字不被windows下的vc6.0支持,举例如下

#include 
void main(void)
{
    printf("%s\n",__FUNCTION__);
    printf("%s\n",__func__);
}


其编译后输出结果为
main
main

注意: “#line”、 “__LINE__”、 “__FILE__" 及 “__func__" 都是大小写敏感的。


 

你可能感兴趣的:(C/C++,程序调试)