在C++中,有一個特殊的成員函數,其名稱和類名是相同的,它不需要來自用戶的顯式調用,而是在創建對象時自動執行,本文是武林技術頻道小編給大家帶來的詳解c++類構造函數,一起來看看吧!
?
/*?? 類對象被創建時,編譯系統對象分配內存空間,并自動調用該構造函數->由構造函數完成成員的初始化工作
???? eg: Counter c1;
???? 編譯系統為對象c1的每個數據成員(m_value)分配內存空間,并調用構造函數Counter( )自動地初始化對象,初始化之后c1的m_value值設置為0
???? 故:構造函數的作用:初始化對象的數據成員。*/
????? class Counter
?????? {
????? public:?????? // 類Counter的構造函數,以類名作為函數名,無返回類型
????? Counter(){
????? m_value = 0;
????? }
????? private:
????? int m_value;? // 類私有的數據成員
????? }
?
//二、 構造函數的種類
#include <iostream>
using namespace std;
class Complex
{
private :
??? double m_real;
??? double m_imag;
public:
//*無參數構造函數
// 如果創建一個類你沒有寫任何構造函數,則系統會自動生成默認的無參構造函數,函數為空,什么都不做
// 只要你寫了一個下面的某一種構造函數,系統就不會再自動生成這樣一個默認的構造函數,如果希望有一個這樣的無參構造函數,則需要自己顯示地寫出來
??? Complex(void)
??? {?? m_real = 0.0;
??????? m_imag = 0.0;
??? }
//*一般構造函數(也稱重載構造函數)
//一般構造函數可以有各種參數形式,一個類可以有多個一般構造函數,前提是參數的個數或者類型不同(基于c++的重載函數原理)
//例如:你還可以寫一個 Complex(int num)的構造函數出來,創建對象時根據傳入的參數不同調用不同的構造函數
??? Complex(double real, double imag)
??? {?? m_real = real;
??????? m_imag = imag;
??? }
//*復制構造函數(也稱為拷貝構造函數)
//復制構造函數參數為類對象本身的引用,用于根據一個已存在的對象復制出一個新的該類的對象,一般在函數中會將已存在對象的數據成員的值復制一份到新創建的對象中
//若沒有顯示的寫復制構造函數,則系統會默認創建一個復制構造函數,但當類中有指針成員時,由系統默認創建該復制構造函數會存在風險,具體原因在有關 “淺拷貝”、“深拷貝”的文章中論述
??? Complex(const Complex & c)
??? {?? // 將對象c中的數據成員值復制過來
??????? m_real = c.m_real;
??????? m_imag = c.m_imag;
??? }
//*類型轉換構造函數,根據一個指定的類型的對象創建一個本類的對象,需要注意的一點是,這個其實就是一般的構造函數,但是對于出現這種單參數的構造函數,C++會默認將參數對應的類型轉換為該類類型,
//有時候這種隱私的轉換是我們所不想要的,所以需要使用explicit來限制這種轉換。
//例如:下面將根據一個double類型的對象創建了一個Complex對象
??? Complex(double r)
??? {?? m_real = r;
??????? m_imag = 0.0;
??? }
// 等號運算符重載(也叫賦值構造函數)
// 注意,這個類似復制構造函數,將=右邊的本類對象的值復制給等號左邊的對象,它不屬于構造函數,等號左右兩邊的對象必須已經被創建。
// 若沒有顯示的寫 =運算符重載,則系統也會創建一個默認的=運算符重載,只做一些基本的拷貝工作
??? Complex &operator=(const Complex &rhs )
??? {?? // 首先檢測等號右邊的是否就是左邊的對象本身,若是本對象本身,則直接返回
??????? if ( this == &rhs )
??????? {?? return *this;
??????? }
??????? // 復制等號右邊的成員到左邊的對象中
??????? this->m_real = rhs.m_real;
??????? this->m_imag = rhs.m_imag;
??????? // 把等號左邊的對象再次傳出,目的是為了支持連等 eg:a=b=c 系統首先運行 b=c 然后運行 a=(b=c的返回值,這里應該是復制c值后的b對象)
??????? return *this;
??? }
};
//三、使用上面定義的類對象來說明各個構造函數的用法:
int main()
{??
??? // 調用了無參構造函數,數據成員初值被賦值為0.0
??? Complex c1,c2;
??? // 調用一般構造函數,數據成員初值分別被賦為指定值
??? Complex c3(1.0,2.5);
??? // 當然,也可以使用下面的形式
??? // Complex c3 = Complex(1.0,2.5);
??? //? 把c3的數據成員的值賦值給事先被創建的對象c1
??? //? 由于c1已經事先被創建,故此處不會調用任何構造函數
??? //? 只會調用 = 號運算符重載函數
??? c1 = c3;?
??? //? 調用類型轉換構造函數
??? //? 系統首先調用類型轉換構造函數,將5.2創建為一個本類的臨時對象,然后調用等號運算符重載,將該臨時對象賦值給c2
??? c2 = 5.2;?
??? // 調用拷貝構造函數( 有下面兩種調用方式)
??? Complex c5(c3);
??? Complex c4 = c3;
??? // 注意和 =運算符重載的區分,這里等號左邊的對象不是事先已經創建,故需要調用拷貝構造函數,參數為c2
??? // 這一點特別重要,這兒是初始化,不是賦值。
??? // 其實這兒就涉及了C++中的兩種初始化的方式:復制初始化和賦值初始化。
??? // 其中c5采用的是復制初始化,而c4采用的是賦值初始化,這兩種方式都是要調用拷貝構造函數的。
}
以上就是關于詳解c++類構造函數的內容了,你學會了嗎?建議你可以收藏這篇文章,相信對于你的編程之路是有著很大好處的,更多的知識你可以來武林技術頻道學習。
新聞熱點
疑難解答
圖片精選