C++ 中類的拷貝、賦值、銷毀的實(shí)例詳解
C++ 中類的拷貝、賦值、銷毀的實(shí)例詳解
本篇文章我們一共講解一下幾個(gè)知識點(diǎn):
類的拷貝構(gòu)造函數(shù)。
類的拷貝賦值運(yùn)算符。
類的析構(gòu)。
好了one by one
如果我們沒有定義類的拷貝構(gòu)造函數(shù)的話,那么編譯器會為我們合成默認(rèn)拷貝構(gòu)造函數(shù)----合成拷貝構(gòu)造函數(shù)。
和成拷貝構(gòu)造函數(shù)的操作是將其參數(shù)的各個(gè)成員拷貝到正在創(chuàng)建的對象中去,每個(gè)成員的類型決定了他是如何被拷貝的:對類類型的成員,會使用其拷貝構(gòu)造函數(shù),內(nèi)置類型的成員則是直接拷貝,雖然我們不能直接拷貝一個(gè)數(shù)組,但是合成拷貝構(gòu)造函數(shù)會逐個(gè)的拷貝一個(gè)數(shù)組類型的成員。
下面我們用代碼演示一下合成拷貝構(gòu)造函數(shù)的功能:
#include <iostream> using namespace std; /* 代碼模仿合成拷貝構(gòu)造函數(shù)的功能 */ class Sales_data { public: Sales_data(); //我們只是為了讀者更好的理解還原了一下合成拷貝構(gòu)造函數(shù)所實(shí)現(xiàn)的功能,實(shí)際上我們是看不見的 Sales_data(const Sales_data& s); ~Sales_data(); private: string bookNo; int units_sold = 0; double revenue = 0.0; }; Sales_data::Sales_data() { } Sales_data::Sales_data(const Sales_data& s) : bookNo(s.bookNo), units_sold(s.units_sold), revenue(s.revenue){ } Sales_data::~Sales_data() { }
好了,我們定義拷貝構(gòu)造函數(shù)也是如此定義的,我解釋一下為什么參數(shù)表里面是一個(gè)靜態(tài)的引用:
1)我們不想改變該引用的值,只是用來進(jìn)行拷貝。
2)我們必須聲明為引用,如果寫成類的話,則又會調(diào)用該類的拷貝構(gòu)造函數(shù),在那個(gè)拷貝構(gòu)造函數(shù)中又會調(diào)用拷貝構(gòu)造函數(shù),這樣陷入死循環(huán)。
我們在來學(xué)習(xí)一下拷貝賦值運(yùn)算符:
和拷貝構(gòu)造函數(shù)一樣,如果我們不定義拷貝賦值運(yùn)算符的話,編譯器將會為我們合成一個(gè),我們下面用代碼來模仿一下吧:
#include <iostream> using namespace std; /* 代碼模仿拷貝賦值運(yùn)算符 */ class Sales_data { public: Sales_data(); //拷貝賦值運(yùn)算符的默認(rèn)合成 Sales_data& operator = (const Sales_data & s); ~Sales_data(); private: string bookNo; int units_sold = 0; double revenue = 0.0; }; Sales_data::Sales_data() { } Sales_data& Sales_data::operator = (const Sales_data & s) { //為什么我們的返回值一定是引用類型呢?這是因?yàn)槲覀兛梢赃M(jìn)行鏈?zhǔn)骄幊潭龅模簊1 = s2 =s3; bookNo = s.bookNo; units_sold = s.units_sold; revenue = s.revenue; return *this; } Sales_data::~Sales_data() { }
好了,我們定義拷貝賦值運(yùn)算符也是如此,我們就不一一贅述了。
我來在來談一談;類的構(gòu)造函數(shù)初始化和類的析構(gòu)函數(shù)銷毀過程的一些細(xì)節(jié)性問題。
1比如我們定義了一個(gè)構(gòu)造函數(shù),實(shí)際上在參數(shù)化賦值列表處及大括號之前,才是我們真正進(jìn)行初始化的地方,在大括號之中做的操作只是進(jìn)行了拷貝賦值操作。
這一點(diǎn)我們要清楚的認(rèn)識到,要不然在對const對象進(jìn)行初始化是就有問題了,因?yàn)閏onst對象只能初始化。
2比如我們定義了一個(gè)析構(gòu)函數(shù),注意了,我們在() {之間的部分才是做了真正的類成員變量的析構(gòu)操作,{}里面使我們進(jìn)行的自定義操作,不一定是什么析構(gòu),應(yīng)為析構(gòu)基本已經(jīng)完成了。
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- c++中深淺拷貝以及寫時(shí)拷貝的實(shí)現(xiàn)示例代碼
- 深入理解C/C++中的寫時(shí)拷貝
- 詳解C++中構(gòu)造函數(shù),拷貝構(gòu)造函數(shù)和賦值函數(shù)的區(qū)別和實(shí)現(xiàn)
- 詳解C++中String類模擬實(shí)現(xiàn)以及深拷貝淺拷貝
- 詳解C++ 編寫String 的構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、析構(gòu)函數(shù)和賦值函數(shù)
- C/C++ 淺拷貝和深拷貝的實(shí)例詳解
- C++基礎(chǔ)教程之指針拷貝詳解
- C++寫時(shí)拷貝實(shí)現(xiàn)原理及實(shí)例解析
相關(guān)文章
解決Visual?Studio?Code錯(cuò)誤Cannot?build?and?debug?because?
這篇文章主要為大家介紹了解決Visual?Studio?Code錯(cuò)誤Cannot?build?and?debug?because?the及分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07C++中std::ios_base::floatfield報(bào)錯(cuò)已解決
在C++編程中,設(shè)置浮點(diǎn)數(shù)輸出格式時(shí)可能遇到std::ios_base::floatfield錯(cuò)誤,解決方法包括使用正確的格式化標(biāo)志組合,避免沖突的格式化設(shè)置,以及檢查流狀態(tài)標(biāo)志是否正確,通過這些方法可以有效避免浮點(diǎn)數(shù)格式化錯(cuò)誤,并確保輸出精確2024-09-09C++?protobuf中對不同消息內(nèi)容進(jìn)行賦值的方式總結(jié)(set_、set_allocated_、mutable_、
這篇文章主要給大家介紹了關(guān)于C++?protobuf中對不同消息內(nèi)容進(jìn)行賦值的方式總結(jié),主要使用的是set_、set_allocated_、mutable_、add_,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03詳解桶排序算法的思路及C++編程中的代碼實(shí)現(xiàn)
桶排序即是先把每個(gè)桶中的元素進(jìn)行排序然后遍歷桶依次列出元素的算法,桶排序在元素較少的情況下很高效,以下我們就來詳解桶排序算法的思路及C++編程中的代碼實(shí)現(xiàn):2016-07-07C++?高精度乘法運(yùn)算的實(shí)現(xiàn)
本文主要介紹了C++?高精度乘法運(yùn)算的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01