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.

順序 選擇 循環 總結


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM