您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“C++構造函數的類型,淺拷貝與深拷貝實例分析”,內容詳細,步驟清晰,細節處理妥當,希望這篇“C++構造函數的類型,淺拷貝與深拷貝實例分析”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
1.如果沒有定義構造函數,則系統自動調用此默認構造函數,且什么都不做。
2.如果用戶自定義了帶參數的構造函數,若還想調用無參的構造函數,必須顯示定義
person() { cout << "this object is being created." << endl; }
一般構造函數可以有各種參數形式,一個類可以有多個一般構造函數,前提是參數的個數或者類型不同(基于c++的重載函數原理)
person(string ID, int age, int height, string sex) { cout<<"含參構造函數調用"<< endl; this.ID = ID; this.age = age; this.height = height; this.sex = sex; }
含參的構造函數還可以使用快速初始化的方法:
person(string ID, int age, int height, string sex) : ID(ID), age(age), height(height), sex(sex) { }
注意:
初始化參數列表和初始化順序不可以變動
變量名稱(不是參數列表名稱)一定要和成員變量名一樣
使用已經創建好的同一類對象,進行構造另一個對象。
person(const person &p) { cout << "拷貝構造函數調用" << endl; this->ID = p.ID; this->age = p.age; this->height = p.height; this->sex = p.sex; }
注意:
但當類中有指針成員時,由系統默認創建該復制構造函數會存在風險,具體原因請查詢有關 “淺拷貝“
淺拷貝,指的是在對象復制時,只對對象中的數據成員進行簡單的賦值,默認拷貝構造函數執行的也是淺拷貝。
例如: person p2 = p1; 這就是淺拷貝,將p1中的成員變量值賦給p2,在這里其實就相當于拷貝構造函數的調用。
但是,淺拷貝,在成員變量是引用類型(指針)時,會出現問題。
傳參問題中,地址傳遞后可以實現swap函數的調用,這就是淺拷貝的原理
當我們使用淺拷貝時,引用類型傳遞的依舊是地址,這也就是說,拷貝后的對象和拷貝的對象中引用對象指向同一塊地址,這樣就出現問題了。
在“深拷貝”的情況下,對于對象中動態成員,就不能僅僅簡單地賦值了,而應該重新動態分配空間。
如果一個類擁有資源,當這個類的對象發生復制過程的時候,資源重新分配,這個過程就是深拷貝。
上面提到,如果沒有自定義復制構造函數,則系統會創建默認的復制構造函數,但系統創建的默認復制構造函數只會執行“淺拷貝”,即將被拷貝對象的數據成員的值一一賦值給新創建的對象,若該類的數據成員中有指針成員,則會使得新的對象的指針所指向的地址與被拷貝對象的指針所指向的地址相同,delete該指針時則會導致兩次重復delete而出錯。
讀到這里,這篇“C++構造函數的類型,淺拷貝與深拷貝實例分析”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。