C++賦值運(yùn)算符
C++當(dāng)中允許類對象賦值,這是通過默認(rèn)的重載賦值運(yùn)算符實(shí)現(xiàn)的,它的原型如下:
Class_name & Class_name::operator=(const Class_name &);
它接受并返回一個指向類對象的引用。
將已有的對象賦給另一個對象時,將會使用重載的賦值運(yùn)算符:
StringBad headline1("Celery");
StringBad knot;
knot = headline1; // 調(diào)用賦值運(yùn)算符如果是對象初始化的過程,則不一定會使用賦值運(yùn)算符,比如:
StringBad metoo = knot;
像是這種情況很難說,因?yàn)?code>metoo是一個新建的對象,它可以使用拷貝構(gòu)造函數(shù)。然而,也可以分成兩步來處理,先使用拷貝構(gòu)造函數(shù)創(chuàng)建一個臨時對象,然后在賦值的時候使用賦值運(yùn)算符復(fù)制到新對象中去也是可以的。
和拷貝構(gòu)造函數(shù)類似,默認(rèn)賦值運(yùn)算符的實(shí)現(xiàn)也是對成員進(jìn)行逐個復(fù)制。如果成員本身就是累對象,那么會使用這個類的賦值運(yùn)算符來復(fù)制。
賦值運(yùn)算符的問題在哪里呢?我們還是看下之前StringBad那個例子,
我們看下下面這段代碼:
StringBad sb("test");
StringBad sports("Spinach Leaves Bowl for Dollars");
StringBad knot;
knot = sports;當(dāng)我們運(yùn)行的時候就會遇到這樣的報錯:

報錯的原因日志里寫得很清楚,我們嘗試釋放一個沒有被分配的內(nèi)存。
會報錯的原因很簡單,因?yàn)槲覀儓?zhí)行knot = sports的時候,兩個對象內(nèi)部的字符串指向的是同一個地址。這就導(dǎo)致了析構(gòu)knot的時候sports對象對應(yīng)的內(nèi)容已經(jīng)不存在了。
解決方案也很簡單,就是我們自己重載賦值運(yùn)算符,保證不會出現(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++賦值運(yùn)算符的文章就介紹到這了,更多相關(guān)C++賦值運(yùn)算符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡單實(shí)例
這篇文章主要介紹了C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡單實(shí)例的相關(guān)資料,希望通過本文能幫助大家實(shí)現(xiàn)優(yōu)先隊(duì)列,需要的朋友可以參考下2017-08-08
C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式
這篇文章主要介紹了C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11
Qt+OpenCV實(shí)現(xiàn)目標(biāo)檢測詳解
這篇文章主要介紹了如何利用Qt和OpenCV中自帶xml文件實(shí)現(xiàn)目標(biāo)檢測,文中的實(shí)現(xiàn)過程講解詳細(xì),感興趣的小伙伴可以動手試一試2022-03-03

