程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> c++類構造函數詳解

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

      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采用的是賦值初始化,這兩種方式都是要調用拷貝構造函數的。

      }

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved