這篇文章主要介紹了解析C++中多層派生時的構造函數及一些特殊形式,特殊形式主要針對基類和子對象類型的構造函數內容,需要的朋友可以參考下
C++多層派生時的構造函數
一個類不僅可以派生出一個派生類,派生類還可以繼續派生,形成派生的層次結構。在上面敘述的基礎上,不難寫出在多級派生情況下派生類的構造函數。
通過例下面的程序,讀者可以了解在多級派生情況下怎樣定義派生類的構造函數。相信大家完全可以自己看懂這個程序。
[例] 多級派生情況下派生類的構造函數。
- #include <iostream>
- #include<string>
- using namespace std;
- class Student//聲明基類
- {
- public://公用部分
- Student(int n, string nam)//基類構造函數
- {
- num=n;
- name=nam;
- }
- void display( )//輸出基類數據成員
- {
- cout<<"num:"<<num<<endl;
- cout<<"name:"<<name<<endl;
- }
- protected://保護部分
- int num;//基類有兩個數據成員
- string name;
- };
- class Student1: public Student//聲明公用派生類Student1
- {
- public:
- Student1(int n,char nam[10],int a):Student(n,nam)//派生類構造函數
- {age=a;}//在此處只對派生類新增的數據成員初始化
- void show( ) //輸出num,name和age
- {
- display( ); //輸出num和name
- cout<<"age: "<<age<<endl;
- }
- private://派生類的私有數據
- int age; //增加一個數據成員
- };
- class Student2:public Student1 //聲明間接公用派生類Student2
- {
- public://下面是間接派生類構造函數
- Student2(int n, string nam,int a,int s):Student1(n,nam,a) {score=s;}
- void show_all( ) //輸出全部數據成員
- {
- show( ); //輸出num和name
- cout<<"score:"<<score<<endl; //輸出age
- }
- private:
- int score; //增加一個數據成員
- };
- int main( )
- {
- Student2 stud(10010,"Li",17,89);
- stud.show_all( ); //輸出學生的全部數據
- return 0;
- }
運行時的輸出如下:
- num:10010
- name:Li
- age:17
- score:89
請注意基類和兩個派生類的構造函數的寫法。
基類的構造函數首部:
- Student(int n, string nam)
派生類Student1的構造函數首部:
- Student1(int n, string nam],int a):Student(n,nam)
派生類Student2的構造函數首部:
- Student2(int n, string nam,int a,int s):Student1(n,nam,a)
注意不要寫成:
- Student2(int n, string nam,int a,int s):Student1(n,nam),student1(n, nam, a)
不要列出每一層派生類的構造函數,只需寫出其上一層派生類(即它的直接基類)的構造函數即可。在聲明Student2類對象時,調用Student2構造函數;在執行Student2構造函數時,先調用Student1構造函數;在執行Student1構造函數時,先調用基類Student構造函數。初始化的順序是:
先初始化基類的數據成員num和name。
再初始化Student1的數據成員age。
最后再初始化Student2的數據成員score。
C++派生類構造函數的特殊形式
在使用派生類構造函數時,有以下特殊的形式。
1) 當不需要對派生類新增的成員進行任何初始化操作時,派生類構造函數的函數體可以為空,即構造函數是空函數,函數體為空時,派生類構造函數的參數個數等于基類構造函數和子對象的參數個數之和,派生類構造函數的全部參數都傳遞給基類構造函數和子對象,在調用派生類構造函數時不對派生類的數據成員初始化。此派生類構造函數的作用只是為了將參數傳遞給基類構造函數和子對象,并在執行派生類構造函數時調用基類構造函數和子對象構造函數。在實際工作中常見這種用法。
2) 如果在基類中沒有定義構造函數,或定義了沒有參數的構造函數,那么在定義派生類構造函數時可不寫基類構造函數。因為此時派生類構造函數沒有向基類構造函數傳遞參數的任務。調用派生類構造函數時系統會自動首先調用基類的默認構造函數。
如果在基類和子對象類型的聲明中都沒有定義帶參數的構造函數,而且也不需對派生類自己的數據成員初始化,則可以不必顯式地定義派生類構造函數。因為此時派生類構造函數既沒有向基類構造函數和子對象構造函數傳遞參數的任務,也沒有對派生類數據成員初始化的任務。
在建立派生類對象時,系統會自動調用系統提供的派生類的默認構造函數,并在執行派生類默認構造函數的過程中,調用基類的默認構造函數和子對象類型默認構造函數。
如果在基類或子對象類型的聲明中定義了帶參數的構造函數,那么就必須顯式地定義派生類構造函數,并在派生類構造函數中寫出基類或子對象類型的構造函數及其參數表。
如果在基類中既定義無參的構造函數,又定義了有參的構造函數(構造函數重載),則在定義派生類構造函數時,既可以包含基類構造函數及其參數,也可以不包含基類構造函數。
在調用派生類構造函數時,根據構造函數的內容決定調用基類的有參的構造函數還是無參的構造函數。編程者可以根據派生類的需要決定采用哪一種方式。
新聞熱點
疑難解答