詳解C++編程中多級派生時的構(gòu)造函數(shù)和訪問屬性
C++多層派生時的構(gòu)造函數(shù)
一個類不僅可以派生出一個派生類,派生類還可以繼續(xù)派生,形成派生的層次結(jié)構(gòu)。在上面敘述的基礎(chǔ)上,不難寫出在多級派生情況下派生類的構(gòu)造函數(shù)。
通過例下面的程序,讀者可以了解在多級派生情況下怎樣定義派生類的構(gòu)造函數(shù)。相信大家完全可以自己看懂這個程序。
[例] 多級派生情況下派生類的構(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://保護部分
int num;//基類有兩個數(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;}//在此處只對派生類新增的數(shù)據(jù)成員初始化
void show( ) //輸出num,name和age
{
display( ); //輸出num和name
cout<<"age: "<<age<<endl;
}
private://派生類的私有數(shù)據(jù)
int age; //增加一個數(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; //增加一個數(shù)據(jù)成員
};
int main( )
{
Student2 stud(10010,"Li",17,89);
stud.show_all( ); //輸出學(xué)生的全部數(shù)據(jù)
return 0;
}
運行時的輸出如下:
num:10010 name:Li age:17 score:89
請注意基類和兩個派生類的構(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類對象時,調(diào)用Student2構(gòu)造函數(shù);在執(zhí)行Student2構(gòu)造函數(shù)時,先調(diào)用Student1構(gòu)造函數(shù);在執(zhí)行Student1構(gòu)造函數(shù)時,先調(diào)用基類Student構(gòu)造函數(shù)。初始化的順序是:
先初始化基類的數(shù)據(jù)成員num和name。
再初始化Student1的數(shù)據(jù)成員age。
最后再初始化Student2的數(shù)據(jù)成員score。
C++類多級派生時的訪問屬性
在實際項目開發(fā)中,經(jīng)常會有多級派生的情況。如圖11.9所示的派生關(guān)系:類A為基類,類B是類A 的派生類,類C是類B的派生類,則類C也是類A的派生類;類B稱為類A 的直接派生類,類C稱為類A的間接派生類;類A是類B的直接基類,是類 C的間接基類。
在多級派生的情況下,各成員的訪問屬性仍按以上原則確定。
為了把多重繼承說的更加詳細,請大家先看下面的幾個繼承的類。
[例] 如果聲明了以下的類:
class A //基類
{
public:
int i;
protected:
void f2( );
int j;
private:
int k;
};
class B: public A //public方式
{
public:
void f3( );
protected:
void f4( );
private:
int m;
};
class C: protected B //protected方式
{
public:
void f5( );
private:
int n;
};
類A是類B的公用基類,類B是類C的保護基類。各成員在不同類中的訪問屬性如下:
根據(jù)以上分析,在派生類C的外面只能訪問類C的成員函數(shù)f5,不能訪問其他成員。 派生類C的成員函數(shù)f5能訪問基類A的成員i、f2、j和派生類B的成員f3、f4。派生類B 的成員函數(shù)f3、f4能訪問基類A的成員i、f2和j。
通過以上分析,可以看到:無論哪一種繼承方式,在派生類中是不能訪問基類的私有成員的,私有成員只能被本類的成員函數(shù)所訪問,畢竟派生類與基類不是同一個類。
如果在多級派生時都采用公用繼承方式,那么直到最后一級派生類都能訪問基類的公用成員和保護成員。
如果采用私有繼承方式,經(jīng)過若干次派生之后,基類的所有的成員已經(jīng)變成不可訪問的了。
如果采用保護繼承方式,在派生類外是無法訪問派生類中的任何成員的。
而且經(jīng)過多次派生后,人們很難清楚地記住哪些成員可以訪問,哪些成員不能訪問,很容易出錯。因此,在實際中,常用的是公用繼承。
上一篇:簡要解讀C++的動態(tài)和靜態(tài)關(guān)聯(lián)以及虛析構(gòu)函數(shù)
欄 目:C語言
本文標題:詳解C++編程中多級派生時的構(gòu)造函數(shù)和訪問屬性
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/2679.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10深入二叉樹兩個結(jié)點的最低共同父結(jié)點的詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計- 解析最少換車次數(shù)的問題詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達式求值的方法詳解
- 01-10HDOJ 1443 約瑟夫環(huán)的最新應(yīng)用分析詳解
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10如何查看進程實際的內(nèi)存占用情況詳解
- 01-10深入Main函數(shù)中的參數(shù)argc,argv的使用詳解


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10C#中split用法實例總結(jié)
- 04-02jquery與jsp,用jquery
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置


