C++11 __cplusplus

【1】__cplusplus

在C与C++混合编写的代码中,常常会在头文件中看到如下形式的声明:

#ifdef __cplusplus
extern "C" {
#endif
// 具体代码......
#ifdef __cplusplus
}
#endif

这种类型的头文件可以被#includeC文件中进行编译,也可以被#includeC++文件中进行编译。

关键点:由于extern"C"可以抑制C++对函数名、变量名等符号(symbol)进行名称重整(name mangling),

因此编译出的C目标文件和C++目标文件中的变量、函数名称等符号都是相同的(否则不相同),链接器可以可靠地对两种类型的目标文件进行链接。

这样该做法成为了CC++混用头文件的典型做法。

为了便于理解,举个例子:

#ifdef __cplusplus
extern "C" {
#endif

void* memset(void*, int, size_t);

#ifdef __cplusplus
}
#endif

由于CC++毕竟不同,为了实现某个程序在CC++中都是兼容的,如果定义两套头文件,未免维护太过麻烦。

因此就有关键字__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.

顺序 选择 循环 总结

posted @ 2020-01-20 21:41  kaizenly  阅读(5904)  评论(0编辑  收藏  举报
打赏