C语言预定义宏与日志打印

1.定义对象宏

标准C语言预处理要求定义某些对象宏,每个预定义宏的名称一两个下划线字符开头和结尾,这些预定义宏不能被取消定义(#undef)或由编程人员重新定义。下面预定义宏表,被我抄了下来。

  • __LINE__  :当前程序行的行号,表示为十进制整型常量
  • __FILE__  :当前源文件名,表示字符串型常量
  • __DATE__ :转换的日历日期,表示为Mmm dd yyyy 形式的字符串常量,Mmm是由asctime产生的。
  • __TIME__  :转换的时间,表示"hh:mm:ss"形式的字符串型常量,是有asctime产生的。(asctime貌似是指的一个函数)
  • __STDC__ :编辑器为ISO兼容实现时位十进制整型常量
  • __STDC_VERSION__  :如何实现复合C89整部1,则这个宏的值为19940SL;如果实现符合C99,则这个宏的值为199901L;否则数值是未定义
  • __STDC_EOBTED__ :(C99)实现为宿主实现时为1,实现为独立实现为0
  • __STDC_IEC_559__ :(C99)浮点数实现复合IBC 60559标准时定义为1,否者数值是未定义
  • __STDC_IEC_559_COMPLEX__: (C99)复数运算实现复合IBC 60559标准时定义为1,否者数值是未定义
  • __STDC_ISO_10646__ :(C99)定义为长整型常量,yyyymmL表示wchar_t值复合ISO 10646标准及其指定年月的修订补充,否则数值未定义

C++中还定义了 __cplusplus

C语言中的__FILE____LINE____DATE__等都在头文件#include<stdio.h>中

其他说明:

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

#include <stdio.h>
 
int main(void)
{
    printf("%d\n",__LINE__);
    printf("%d\n",__LINE__);
    printf("%d\n",__LINE__);
    printf("%s\n",__FILE__);

    printf("%s\n",__DATE__);
	printf("%s\n",__TIME__);
    return 0;
}

2.打印日志

有些时候,需要在Log中打出进程或线程的ID,以便调试、查找问题。

获取进程ID

#include <unistd.h>
pid_t getpid(void);

获取线程ID

// 方法1
#include <sys/syscall.h>
syscall(__NR_gettid)

// 方法2
#include <sys/syscall.h>
#define gettid() syscall(__NR_gettid)

// 方法3
#include <sys/syscall.h>
#define gettid() syscall(SYS_gettid)

当只有一个线程的时候,返回的是pid。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

scott198512

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值