37.拷贝控制和资源管理
類中只要有一個(gè)成員不可能拷貝、賦值、析構(gòu)的話,類的合成拷貝控制成員就被定義為delete
在新標(biāo)準(zhǔn)發(fā)布之前,要想阻止拷貝,類將拷貝構(gòu)造函數(shù)和拷貝賦值運(yùn)算符聲明為private,只是聲明,沒有給出定義。
這樣一來(lái),試圖拷貝對(duì)象的用戶代碼在編譯階段就會(huì)被標(biāo)記為錯(cuò)誤。成員函數(shù)或者友元函數(shù)中的拷貝操作將會(huì)導(dǎo)致鏈接時(shí)錯(cuò)誤。
定義行為像值的類
當(dāng)我們拷貝一個(gè)像值的對(duì)象時(shí),副本和原對(duì)象是完全獨(dú)立的。改變副本不會(huì)對(duì)原對(duì)象有任何影響。
using namespace std;class has {string* str;int i; public:has(const string& s = string()) :str(new string (s)), i(0) {}has(const has & h) :str(new string(*h.str)), i(h.i) {}has& operator=(const has &);~has() { delete str; }};has& has::operator=(const has& hs) {string* tmp = new string(*hs.str);delete str;str = tmp;i = hs.i;return *this; }當(dāng)我們編寫賦值運(yùn)算符的時(shí)候,有兩點(diǎn)需要記住:
1)如果將一個(gè)對(duì)象賦值給對(duì)象本身的話,賦值運(yùn)算符必須能夠正確工作;
2)大多數(shù)的賦值運(yùn)算符組合了拷貝構(gòu)造函數(shù)和析構(gòu)函數(shù)的工作。
當(dāng)你在編寫一個(gè)賦值運(yùn)算符的時(shí)候,一個(gè)好的模式是:
先將等號(hào)右側(cè)的對(duì)象拷貝到一個(gè)臨時(shí)的對(duì)象中。當(dāng)拷貝完成之后,銷毀左側(cè)的對(duì)象的現(xiàn)有成員就是安全的了。一旦左側(cè)的運(yùn)算對(duì)象的資源被銷毀的話,就只剩下將臨時(shí)對(duì)象的資源拷貝到左側(cè)的運(yùn)算對(duì)象的成員之中。
定義行為像指針的類
采用計(jì)數(shù)器機(jī)制,對(duì)象的拷貝不會(huì)改變底層的結(jié)構(gòu),也就是說(shuō)。當(dāng)一個(gè)對(duì)象,另一個(gè)對(duì)象隨之改變。
using namespace std;class has {string* str;int i;size_t* use; public:has(const string & s = string()) :str(new string(s)), i(0), use(new size_t(1)) {}has(const has& hs) :str(hs.str), i(hs.i), use(hs.use) {}has& operator=(const has& h);~has(); };has& has::operator=(const has &h) {++*h.use;if (--*use == 0){delete str;delete use;}str = h.str;i = h.i;use = h.use;return *this;}has::~has() {if (--*use == 0){delete str;delete use;} }?
?
?
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的37.拷贝控制和资源管理的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。