C++中的三大函數(shù)和操作符重載(Boolan)
C++中三大函數(shù):
- 析構(gòu)函數(shù)
- 復(fù)制構(gòu)造函數(shù)
- =操作符(copy assignment operator)
這三個特殊的成員函數(shù)如果程序員沒有實現(xiàn),編譯器將提供默認(rèn)的實現(xiàn)方式。
析構(gòu)函數(shù):
形如~foo_t(),函數(shù)名和構(gòu)造函數(shù)相同,前面加~,如果對象是自由變量創(chuàng)建,析構(gòu)函數(shù)將在脫離作用域時調(diào)用。如果對象是通過new操作符創(chuàng)建的,則通過delete操作符調(diào)用析構(gòu)函數(shù)。
復(fù)制構(gòu)造函數(shù):
形如foo_t(const foo_t& foo),以下情況復(fù)制構(gòu)造函數(shù)均會被調(diào)用:
- 當(dāng)對象按值返回時候(returned by value)
- 調(diào)用按值傳參的函數(shù)(passed by value)
- 通過thrown拋出或caught捕獲的對象
- 對象處于()包圍的初始化列表中
=操作符:
重載=操作符,如foo_t& operator=(const foo_t& foo),對已有對象的賦值操作將調(diào)用該函數(shù)(未初始化的對象成員將調(diào)用復(fù)制構(gòu)造函數(shù))。
以下為代碼實例:
#include <cstring> #include <iostream> class foo_t { friend std::ostream &operator<<(std::ostream &os, foo_t const &foo) { os << foo.data; return os; } public: foo_t(void) : data(new char[14]) { std::strcpy(data, "Hello, World!"); } ~foo_t(void) { delete[] data; } foo_t(const foo_t& other); foo_t &operator=(const foo_t& other); private: char *data; }; foo_t::foo_t(const foo_t& other) { std::cout << "call copy constructor!!!" << std::endl; this->data = new char[strlen(other.data) + 1]; strcpy(this->data, other.data); } foo_t& foo_t::operator=(const foo_t& other) { std::cout << "call the copy assignment operator!!!" << std::endl; if (this == &other) return *this; this->data = new char[strlen(other.data) + 1]; strcpy(this->data, other.data); return *this; } int main() { foo_t foo; std::cout << foo << '\n'; foo_t t(foo); // foo_t t2 = t; foo_t t3; t3 = t; return 0; }
為了方便測試,可以分別在析構(gòu)函數(shù)、拷貝構(gòu)造、=重載處設(shè)置斷點,觀察程序執(zhí)行流程。
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
C++ 數(shù)據(jù)結(jié)構(gòu)之布隆過濾器
這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)之布隆過濾器的相關(guān)資料,需要的朋友可以參考下2017-06-06C語言實現(xiàn)通訊錄系統(tǒng)課程設(shè)計
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)通訊錄系統(tǒng)課程設(shè)計,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07C語言數(shù)據(jù)結(jié)構(gòu)與算法之鏈表(一)
鏈表是線性表的鏈?zhǔn)酱鎯Ψ绞?。鏈表的?nèi)存是不連續(xù)的,前一個元素存儲地址的下一個地址中存儲的不一定是下一個元素。小編今天就將帶大家深入了解一下鏈表,快來學(xué)習(xí)吧2021-12-12