您好,登錄后才能下訂單哦!
這篇文章主要介紹C++中NULL與nullptr的區(qū)別有什么不同,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
在C語言中,NULL通常被定義為:#define NULL ((void *)0)
所以說NULL實(shí)際上是一個空指針,如果在C語言中寫入以下代碼,編譯是沒有問題的,因?yàn)樵贑語言中把空指針賦給int和char指針的時候,發(fā)生了隱式類型轉(zhuǎn)換,把void指針轉(zhuǎn)換成了相應(yīng)類型的指針。
int *pi = NULL; char *pc = NULL;
但是問題來了,以上代碼如果使用C++編譯器來編譯則是會出錯的,因?yàn)镃++是強(qiáng)類型語言,void*是不能隱式轉(zhuǎn)換成其他類型的指針的,所以實(shí)際上編譯器提供的頭文件做了相應(yīng)的處理:
#ifdef __cplusplus #define NULL 0 #else #define NULL ((void *)0) #endif
可見,在C++中,NULL實(shí)際上是0.因?yàn)镃++中不能把void*類型的指針隱式轉(zhuǎn)換成其他類型的指針,所以為了結(jié)果空指針的表示問題,C++引入了0來表示空指針,這樣就有了上述代碼中的NULL宏定義。
但是實(shí)際上,用NULL代替0表示空指針在函數(shù)重載時會出現(xiàn)問題,程序執(zhí)行的結(jié)果會與我們的想法不同,舉例如下:
#include <iostream> using namespace std; void func(void* i) { cout << "func1" << endl; } void func(int i) { cout << "func2" << endl; } void main(int argc,char* argv[]) { func(NULL); func(nullptr); getchar(); }
在這段代碼中,我們對函數(shù)func進(jìn)行可重載,參數(shù)分別是void*類型和int類型,但是運(yùn)行結(jié)果卻與我們使用NULL的初衷是相違背的,因?yàn)槲覀儽緛硎窍胗肗ULL來代替空指針,但是在將NULL輸入到函數(shù)中時,它卻選擇了int形參這個函數(shù)版本,所以是有問題的,這就是用NULL代替空指針在C++程序中的二義性。
為解決NULL代指空指針存在的二義性問題,在C++11版本(2011年發(fā)布)中特意引入了nullptr這一新的關(guān)鍵字來代指空指針,從上面的例子中我們可以看到,使用nullptr作為實(shí)參,確實(shí)選擇了正確的以void*作為形參的函數(shù)版本。
NULL在C++中就是0,這是因?yàn)樵贑++中void* 類型是不允許隱式轉(zhuǎn)換成其他類型的,所以之前C++中用0來代表空指針,但是在重載整形的情況下,會出現(xiàn)上述的問題。所以,C++11加入了nullptr,可以保證在任何情況下都代表空指針,而不會出現(xiàn)上述的情況,因此,建議以后還是都用nullptr替代NULL吧,而NULL就當(dāng)做0使用。
其他:在沒有C++ 11的nullptr的時候,我們怎么解決避免這個問題呢?
const class nullptr_t { public: template<class T> inline operator T*() const { return 0; } template<class C, class T> inline operator T C::*() const { return 0; } private: void operator&() const; } nullptr = {};
以上是“C++中NULL與nullptr的區(qū)別有什么不同”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。