c++類的建構函式詳解

來源:互聯網
上載者:User

一、 建構函式是幹什麼的
class Counter
{
public:
         // 類Counter的建構函式
         // 特點:以類名作為函數名,無傳回型別
         Counter()
         {
                m_value = 0;
         }
private:
          // 資料成員
         int m_value;
}
       該類對象被建立時,編譯系統對象分配記憶體空間,並自動調用該建構函式->由建構函式完成成員的初始化工作
eg:    Counter c1;
       編譯系統為對象c1的每個資料成員(m_value)分配記憶體空間,並調用建構函式Counter( )自動地初始化對象c1的m_value值設定為0
故:
        建構函式的作用:初始化對象的資料成員。
二、 建構函式的種類
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建立為一個本類的臨時對象,然後調用等號運算子多載,將該臨時對象賦值給c1
        c2 = 5.2;       
       // 調用拷貝建構函式( 有下面兩種調用方式)
        Complex c5(c2);
        Complex c4 = c2;  // 注意和 = 運算子多載區分,這裡等號左邊的對象不是事先已經建立,故需要調用拷貝建構函式,參數為c2
//這一點特別重要,這兒是初始化,不是賦值。其實這兒就涉及了C++中的兩種初始化的方式:複製初始化和賦值初始化。其中c5採用的是複製初始化,而c4採用的是賦值初始化,這兩種方式都是要調用拷貝建構函式的。
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.