C++賦值運(yùn)算符
C++當(dāng)中允許類(lèi)對(duì)象賦值,這是通過(guò)默認(rèn)的重載賦值運(yùn)算符實(shí)現(xiàn)的,它的原型如下:
Class_name & Class_name::operator=(const Class_name &);
它接受并返回一個(gè)指向類(lèi)對(duì)象的引用。
將已有的對(duì)象賦給另一個(gè)對(duì)象時(shí),將會(huì)使用重載的賦值運(yùn)算符:
StringBad headline1("Celery"); StringBad knot; knot = headline1; // 調(diào)用賦值運(yùn)算符
如果是對(duì)象初始化的過(guò)程,則不一定會(huì)使用賦值運(yùn)算符,比如:
StringBad metoo = knot;
像是這種情況很難說(shuō),因?yàn)?code>metoo是一個(gè)新建的對(duì)象,它可以使用拷貝構(gòu)造函數(shù)。然而,也可以分成兩步來(lái)處理,先使用拷貝構(gòu)造函數(shù)創(chuàng)建一個(gè)臨時(shí)對(duì)象,然后在賦值的時(shí)候使用賦值運(yùn)算符復(fù)制到新對(duì)象中去也是可以的。
和拷貝構(gòu)造函數(shù)類(lèi)似,默認(rèn)賦值運(yùn)算符的實(shí)現(xiàn)也是對(duì)成員進(jìn)行逐個(gè)復(fù)制。如果成員本身就是累對(duì)象,那么會(huì)使用這個(gè)類(lèi)的賦值運(yùn)算符來(lái)復(fù)制。
賦值運(yùn)算符的問(wèn)題在哪里呢?我們還是看下之前StringBad
那個(gè)例子,
我們看下下面這段代碼:
StringBad sb("test"); StringBad sports("Spinach Leaves Bowl for Dollars"); StringBad knot; knot = sports;
當(dāng)我們運(yùn)行的時(shí)候就會(huì)遇到這樣的報(bào)錯(cuò):
報(bào)錯(cuò)的原因日志里寫(xiě)得很清楚,我們嘗試釋放一個(gè)沒(méi)有被分配的內(nèi)存。
會(huì)報(bào)錯(cuò)的原因很簡(jiǎn)單,因?yàn)槲覀儓?zhí)行knot = sports
的時(shí)候,兩個(gè)對(duì)象內(nèi)部的字符串指向的是同一個(gè)地址。這就導(dǎo)致了析構(gòu)knot
的時(shí)候sports
對(duì)象對(duì)應(yīng)的內(nèi)容已經(jīng)不存在了。
解決方案也很簡(jiǎn)單,就是我們自己重載賦值運(yùn)算符,保證不會(huì)出現(xiàn)簡(jiǎn)單拷貝的問(wè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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++簡(jiǎn)單實(shí)現(xiàn)的全排列算法示例
這篇文章主要介紹了C++簡(jiǎn)單實(shí)現(xiàn)的全排列算法,結(jié)合實(shí)例形式分析了C++排序操作的實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-07-07C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡(jiǎn)單實(shí)例
這篇文章主要介紹了C++ 實(shí)現(xiàn)優(yōu)先隊(duì)列的簡(jiǎn)單實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助大家實(shí)現(xiàn)優(yōu)先隊(duì)列,需要的朋友可以參考下2017-08-08C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式
這篇文章主要介紹了C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11Qt+OpenCV實(shí)現(xiàn)目標(biāo)檢測(cè)詳解
這篇文章主要介紹了如何利用Qt和OpenCV中自帶xml文件實(shí)現(xiàn)目標(biāo)檢測(cè),文中的實(shí)現(xiàn)過(guò)程講解詳細(xì),感興趣的小伙伴可以動(dòng)手試一試2022-03-03