C++賦值運算符
C++當中允許類對象賦值,這是通過默認的重載賦值運算符實現(xiàn)的,它的原型如下:
Class_name & Class_name::operator=(const Class_name &);
它接受并返回一個指向類對象的引用。
將已有的對象賦給另一個對象時,將會使用重載的賦值運算符:
StringBad headline1("Celery"); StringBad knot; knot = headline1; // 調(diào)用賦值運算符
如果是對象初始化的過程,則不一定會使用賦值運算符,比如:
StringBad metoo = knot;
像是這種情況很難說,因為metoo
是一個新建的對象,它可以使用拷貝構(gòu)造函數(shù)。然而,也可以分成兩步來處理,先使用拷貝構(gòu)造函數(shù)創(chuàng)建一個臨時對象,然后在賦值的時候使用賦值運算符復(fù)制到新對象中去也是可以的。
和拷貝構(gòu)造函數(shù)類似,默認賦值運算符的實現(xiàn)也是對成員進行逐個復(fù)制。如果成員本身就是累對象,那么會使用這個類的賦值運算符來復(fù)制。
賦值運算符的問題在哪里呢?我們還是看下之前StringBad
那個例子,
我們看下下面這段代碼:
StringBad sb("test"); StringBad sports("Spinach Leaves Bowl for Dollars"); StringBad knot; knot = sports;
當我們運行的時候就會遇到這樣的報錯:
報錯的原因日志里寫得很清楚,我們嘗試釋放一個沒有被分配的內(nèi)存。
會報錯的原因很簡單,因為我們執(zhí)行knot = sports
的時候,兩個對象內(nèi)部的字符串指向的是同一個地址。這就導(dǎo)致了析構(gòu)knot
的時候sports
對象對應(yīng)的內(nèi)容已經(jīng)不存在了。
解決方案也很簡單,就是我們自己重載賦值運算符,保證不會出現(xiàn)簡單拷貝的問題。
StringBad & StringBad::operator= (const StringBad & st) { ? ? if (this == &st) return *this; ? ? delete []str; ? ? len = st.len; ? ? str = new char[len+1]; ? ? std::strcpy(str, st.str); ? ? return *this; }
到此這篇關(guān)于C++賦值運算符的文章就介紹到這了,更多相關(guān)C++賦值運算符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式
這篇文章主要介紹了C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11