37.拷贝控制和资源管理
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                37.拷贝控制和资源管理
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                類中只要有一個成員不可能拷貝、賦值、析構的話,類的合成拷貝控制成員就被定義為delete
在新標準發布之前,要想阻止拷貝,類將拷貝構造函數和拷貝賦值運算符聲明為private,只是聲明,沒有給出定義。
這樣一來,試圖拷貝對象的用戶代碼在編譯階段就會被標記為錯誤。成員函數或者友元函數中的拷貝操作將會導致鏈接時錯誤。
定義行為像值的類
當我們拷貝一個像值的對象時,副本和原對象是完全獨立的。改變副本不會對原對象有任何影響。
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; }當我們編寫賦值運算符的時候,有兩點需要記住:
1)如果將一個對象賦值給對象本身的話,賦值運算符必須能夠正確工作;
2)大多數的賦值運算符組合了拷貝構造函數和析構函數的工作。
當你在編寫一個賦值運算符的時候,一個好的模式是:
先將等號右側的對象拷貝到一個臨時的對象中。當拷貝完成之后,銷毀左側的對象的現有成員就是安全的了。一旦左側的運算對象的資源被銷毀的話,就只剩下將臨時對象的資源拷貝到左側的運算對象的成員之中。
定義行為像指針的類
采用計數器機制,對象的拷貝不會改變底層的結構,也就是說。當一個對象,另一個對象隨之改變。
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;} }?
?
?
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的37.拷贝控制和资源管理的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        