在看一些代码的时候偶然看到了一些类似于static void bad_signal __P((int))这种在定义时使用了__P的函数。__P这种东西以前没有用过,于是在网上查了下信息,结果如下(以下信息来自网络):
__P系统定义的宏,定义它的原因是ANSI C之前的老编译器不支持函数原型定义,使用__P宏为ANSI和非ANSI的编译器提供了一种可移植的方案。其定义如下:
# if defined(__STDC__) || defined(__GNUC__)
# define __P(x) x
# else
# define __P(x) ()
# endif
这样ANSIC的编译器会把这句编译为extern void _sig_ign(int sig);
非ANSI C的编译器会把它编译为 extern void _sig_ign();
均不会报错,这样使得在不同编译器下都可以使用,增加了代码的可移植性。
除了上面在网上找到信息之外,在/usr/include/sys/cdefs.h的第72行开始可以看到如下定义:
72 /* These two macros are not used in glibc anymore. They are kept here
73 only because some other projects expect the macros to be defined. */
74 #define __P(args) args
75 #define __PMT(args) args
也表明是为了增加编译器的兼容性而设置的。
__P这个宏我们平时写代码时可能几乎很少用到,但个人觉得毕竟是干这行的,就算不用也还是要知道它的意思才行。就当了解一下C语言的发展史喽:)
阅读(2460) | 评论(1) | 转发(0) |