【1】__cplusplus
在C与C++混合编写的代码中,常常会在头文件中看到如下形式的声明:
#ifdef __cplusplus extern "C" { #endif // 具体代码...... #ifdef __cplusplus } #endif
这种类型的头文件可以被#include到C文件中进行编译,也可以被#include到C++文件中进行编译。
关键点:由于extern"C"可以抑制C++对函数名、变量名等符号(symbol)进行名称重整(name mangling),
因此编译出的C目标文件和C++目标文件中的变量、函数名称等符号都是相同的(否则不相同),链接器可以可靠地对两种类型的目标文件进行链接。
这样该做法成为了C与C++混用头文件的典型做法。
为了便于理解,举个例子:
#ifdef __cplusplus extern "C" { #endif void* memset(void*, int, size_t); #ifdef __cplusplus } #endif
由于C和C++毕竟不同,而为了实现某个程序在C和C++中都是兼容的,如果定义两套头文件,未免维护太过麻烦。
因此就有关键字__cplusplus的出现,这个关键字是在C++中特有的,__cplusplus其实就是C++。
如上这段代码是在C++文件中出现,那么经过条件编译后,该段代码就变成:
/**************C++文件中条件编译后结果***************/ extern "C" { void* memset(void*, int, size_t); }
如上这段代码是在C文件中出现,那么经过条件编译后,该段代码就变成:
/**********C文件中条件编译后结果*************/ void* memset(void*, int, size_t);
【2】C++11 __cplusplus重点
鉴于以上的做法,程序员可能认为__cplusplus这个宏只有“被定义了”和“未定义”两种状态。
事实上却并非如此,__cplusplus这个宏通常被定义为一个整型值。
而且随着标准变化,__cplusplus宏一般会是一个比以往标准中更大的值。
比如在C++03标准中,__cplusplus的值被预定为199711L,而在C++11标准中,宏__cplusplus被预定义为201103L。
这点变化可以为代码所用,比如程序员在想确定代码是使用支持C++11编译器进行编译时,那么可以按下面的方法进行检测:
#if __cplusplus < 201103L #error should use C++ 11 implementation #endif
good good study, day day up.
顺序 选择 循环 总结