【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.
順序 選擇 循環 總結
