解析C++中多層派生時(shí)的構(gòu)造函數(shù)及一些特殊形式
C++多層派生時(shí)的構(gòu)造函數(shù)
一個(gè)類不僅可以派生出一個(gè)派生類,派生類還可以繼續(xù)派生,形成派生的層次結(jié)構(gòu)。在上面敘述的基礎(chǔ)上,不難寫出在多級(jí)派生情況下派生類的構(gòu)造函數(shù)。
通過例下面的程序,讀者可以了解在多級(jí)派生情況下怎樣定義派生類的構(gòu)造函數(shù)。相信大家完全可以自己看懂這個(gè)程序。
[例] 多級(jí)派生情況下派生類的構(gòu)造函數(shù)。
#include <iostream> #include<string> using namespace std; class Student//聲明基類 { public://公用部分 Student(int n, string nam)//基類構(gòu)造函數(shù) { num=n; name=nam; } void display( )//輸出基類數(shù)據(jù)成員 { cout<<"num:"<<num<<endl; cout<<"name:"<<name<<endl; } protected://保護(hù)部分 int num;//基類有兩個(gè)數(shù)據(jù)成員 string name; }; class Student1: public Student//聲明公用派生類Student1 { public: Student1(int n,char nam[10],int a):Student(n,nam)//派生類構(gòu)造函數(shù) {age=a;}//在此處只對(duì)派生類新增的數(shù)據(jù)成員初始化 void show( ) //輸出num,name和age { display( ); //輸出num和name cout<<"age: "<<age<<endl; } private://派生類的私有數(shù)據(jù) int age; //增加一個(gè)數(shù)據(jù)成員 }; class Student2:public Student1 //聲明間接公用派生類Student2 { public://下面是間接派生類構(gòu)造函數(shù) Student2(int n, string nam,int a,int s):Student1(n,nam,a) {score=s;} void show_all( ) //輸出全部數(shù)據(jù)成員 { show( ); //輸出num和name cout<<"score:"<<score<<endl; //輸出age } private: int score; //增加一個(gè)數(shù)據(jù)成員 }; int main( ) { Student2 stud(10010,"Li",17,89); stud.show_all( ); //輸出學(xué)生的全部數(shù)據(jù) return 0; }
運(yùn)行時(shí)的輸出如下:
num:10010 name:Li age:17 score:89
請(qǐng)注意基類和兩個(gè)派生類的構(gòu)造函數(shù)的寫法。
基類的構(gòu)造函數(shù)首部:
Student(int n, string nam)
派生類Student1的構(gòu)造函數(shù)首部:
Student1(int n, string nam],int a):Student(n,nam)
派生類Student2的構(gòu)造函數(shù)首部:
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)
不要列出每一層派生類的構(gòu)造函數(shù),只需寫出其上一層派生類(即它的直接基類)的構(gòu)造函數(shù)即可。在聲明Student2類對(duì)象時(shí),調(diào)用Student2構(gòu)造函數(shù);在執(zhí)行Student2構(gòu)造函數(shù)時(shí),先調(diào)用Student1構(gòu)造函數(shù);在執(zhí)行Student1構(gòu)造函數(shù)時(shí),先調(diào)用基類Student構(gòu)造函數(shù)。初始化的順序是:
先初始化基類的數(shù)據(jù)成員num和name。
再初始化Student1的數(shù)據(jù)成員age。
最后再初始化Student2的數(shù)據(jù)成員score。
C++派生類構(gòu)造函數(shù)的特殊形式
在使用派生類構(gòu)造函數(shù)時(shí),有以下特殊的形式。
1) 當(dāng)不需要對(duì)派生類新增的成員進(jìn)行任何初始化操作時(shí),派生類構(gòu)造函數(shù)的函數(shù)體可以為空,即構(gòu)造函數(shù)是空函數(shù),函數(shù)體為空時(shí),派生類構(gòu)造函數(shù)的參數(shù)個(gè)數(shù)等于基類構(gòu)造函數(shù)和子對(duì)象的參數(shù)個(gè)數(shù)之和,派生類構(gòu)造函數(shù)的全部參數(shù)都傳遞給基類構(gòu)造函數(shù)和子對(duì)象,在調(diào)用派生類構(gòu)造函數(shù)時(shí)不對(duì)派生類的數(shù)據(jù)成員初始化。此派生類構(gòu)造函數(shù)的作用只是為了將參數(shù)傳遞給基類構(gòu)造函數(shù)和子對(duì)象,并在執(zhí)行派生類構(gòu)造函數(shù)時(shí)調(diào)用基類構(gòu)造函數(shù)和子對(duì)象構(gòu)造函數(shù)。在實(shí)際工作中常見這種用法。
2) 如果在基類中沒有定義構(gòu)造函數(shù),或定義了沒有參數(shù)的構(gòu)造函數(shù),那么在定義派生類構(gòu)造函數(shù)時(shí)可不寫基類構(gòu)造函數(shù)。因?yàn)榇藭r(shí)派生類構(gòu)造函數(shù)沒有向基類構(gòu)造函數(shù)傳遞參數(shù)的任務(wù)。調(diào)用派生類構(gòu)造函數(shù)時(shí)系統(tǒng)會(huì)自動(dòng)首先調(diào)用基類的默認(rèn)構(gòu)造函數(shù)。
如果在基類和子對(duì)象類型的聲明中都沒有定義帶參數(shù)的構(gòu)造函數(shù),而且也不需對(duì)派生類自己的數(shù)據(jù)成員初始化,則可以不必顯式地定義派生類構(gòu)造函數(shù)。因?yàn)榇藭r(shí)派生類構(gòu)造函數(shù)既沒有向基類構(gòu)造函數(shù)和子對(duì)象構(gòu)造函數(shù)傳遞參數(shù)的任務(wù),也沒有對(duì)派生類數(shù)據(jù)成員初始化的任務(wù)。
在建立派生類對(duì)象時(shí),系統(tǒng)會(huì)自動(dòng)調(diào)用系統(tǒng)提供的派生類的默認(rèn)構(gòu)造函數(shù),并在執(zhí)行派生類默認(rèn)構(gòu)造函數(shù)的過程中,調(diào)用基類的默認(rèn)構(gòu)造函數(shù)和子對(duì)象類型默認(rèn)構(gòu)造函數(shù)。
如果在基類或子對(duì)象類型的聲明中定義了帶參數(shù)的構(gòu)造函數(shù),那么就必須顯式地定義派生類構(gòu)造函數(shù),并在派生類構(gòu)造函數(shù)中寫出基類或子對(duì)象類型的構(gòu)造函數(shù)及其參數(shù)表。
如果在基類中既定義無參的構(gòu)造函數(shù),又定義了有參的構(gòu)造函數(shù)(構(gòu)造函數(shù)重載),則在定義派生類構(gòu)造函數(shù)時(shí),既可以包含基類構(gòu)造函數(shù)及其參數(shù),也可以不包含基類構(gòu)造函數(shù)。
在調(diào)用派生類構(gòu)造函數(shù)時(shí),根據(jù)構(gòu)造函數(shù)的內(nèi)容決定調(diào)用基類的有參的構(gòu)造函數(shù)還是無參的構(gòu)造函數(shù)。編程者可以根據(jù)派生類的需要決定采用哪一種方式。
- 淺談C++中的構(gòu)造函數(shù)分類及調(diào)用規(guī)則
- 詳解C++中如何將構(gòu)造函數(shù)或析構(gòu)函數(shù)的訪問權(quán)限定為private
- 完全掌握C++編程中構(gòu)造函數(shù)使用的超級(jí)學(xué)習(xí)教程
- 深入解析C++中派生類的構(gòu)造函數(shù)
- 詳解C++編程中多級(jí)派生時(shí)的構(gòu)造函數(shù)和訪問屬性
- 解析C++中構(gòu)造函數(shù)的默認(rèn)參數(shù)和構(gòu)造函數(shù)的重載
- C++聚合關(guān)系類的構(gòu)造函數(shù)的調(diào)用順序詳解
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(768.可排序的最大塊數(shù)之二)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(768.可排序的最大塊數(shù)之二),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C語言數(shù)據(jù)結(jié)構(gòu)深入探索順序表
順序表,全名順序存儲(chǔ)結(jié)構(gòu),是線性表的一種,線性表用于存儲(chǔ)邏輯關(guān)系為“一對(duì)一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對(duì)數(shù)據(jù)的物理存儲(chǔ)結(jié)構(gòu)也有要求,跟隨下文來具體了解吧2022-03-03C語言實(shí)現(xiàn)對(duì)文件進(jìn)行操作的示例詳解
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)對(duì)文件進(jìn)行操作的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C語言有一定的幫助,需要的可以參考一下2023-04-04C語言詳解實(shí)現(xiàn)猜數(shù)字游戲步驟
猜數(shù)字是興起于英國的益智類小游戲,起源于20世紀(jì)中期,一般由兩個(gè)人或多人玩,也可以由一個(gè)人和電腦玩。游戲規(guī)則為一方出數(shù)字,一方猜,今天我們來實(shí)現(xiàn)這個(gè)游戲案例2022-07-07