Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2642424
  • 博文数量: 333
  • 博客积分: 4817
  • 博客等级: 上校
  • 技术积分: 4413
  • 用 户 组: 普通用户
  • 注册时间: 2011-02-28 10:51
文章分类

全部博文(333)

文章存档

2017年(20)

2016年(57)

2015年(27)

2014年(20)

2013年(21)

2012年(164)

2011年(24)

分类: LINUX

2012-06-06 09:33:17

C标准中一些预定义的宏
   C标准中指定了一些预定义的宏,对于编程经常会用到。下面这个表中就是一些常常用到的预定义宏。
  宏
  意义
  __DATE__
  进行预处理的日期(“Mmm dd yyyy”形式的字符串文字)
  __FILE__
  代表当前源代码文件名的字符串文字
  __LINE__
  代表当前源代码中的行号的整数常量
  __TIME__
  源文件编译时间,格式微“hh:mm:ss”
  __func__
  当前所在函数名
  
   对于__FILE__,__LINE__,__func__这样的宏,在调试程序时是很有用的,因为你可以很容易的知道程序运行到了哪个文件的那一行,是哪个函数。
   下面一个例子是打印上面这些预定义的宏的。
#include
#include

void why_me();

int main()
{
    printf( "The file is %s.\n", __FILE__ );
    printf( "The date is %s.\n", __DATE__ );
    printf( "The time is %s.\n", __TIME__ );
    printf( "This is line %d.\n", __LINE__ );
    printf( "This function is %s.\n", __func__ );

    why_me();

     return 0;
}

void why_me()
{
    printf( "This function is %s\n", __func__ );
    printf( "The file is %s.\n", __FILE__ );
    printf( "This is line %d.\n", __LINE__ );
}

打印信息:
The file is debug.c.
The date is Jun  6 2012.
The time is 09:36:28.
This is line 15.
This function is main.
This function is why_me
The file is debug.c.
This is line 27.

阅读(22825) | 评论(1) | 转发(5) |
给主人留下些什么吧!~~

郝姬友2017-02-08 14:44:02

谢谢分享