一 概述
本节课的内容是多重继承,由于前面在继承那一章已经粗略地了解了多重继承,所以本节及后面几节主要是说明"为什么要用多重继承".
二 为什么要用多重继承
- 为什么要使用多重继承呢?举个非常简单的例子,一对夫妻生了一个儿子,假设这个儿子只继承了父亲的特点,那么就是单一继承,但是这种情况往往是不多见的,一般情况下都是儿子既继承了父亲的特点,又继承了母亲的特点
- 在没有多重继承之前,假如这个儿子既继承了父亲的聪明,又继承了母亲的美丽,那么就只好在父亲类里添加一项功能,就是美丽
- 由于父亲不美丽,所以该父类中的beautiful函数什么功能都没有,只是起到一个接口的作用,目的是为了让son类来继承
三 示例演示及结果输出
3.1 代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
| #include<iostream> using namespace std; class father{
public: void smart(){cout<<"父亲很聪明"<<endl;} virtual void beautiful(){} virtual ~father(){cout<<"析构father"<<endl;}
};
class son:public father { public: virtual void beautiful(){cout<<"儿子也很帅"<<endl;} ~son(){cout<<"析构son"<<endl;}
}; int main() { father *pf; int choice=0; while(choice<99) { bool quit=false; cout<<"(0)退出(1)父亲(2)儿子:"; cin>>choice; switch(choice) { case 0:quit=true; break; case 1:pf=new father; break; case 2:pf=new son; pf->beautiful(); pf->smart(); delete pf; break; default:cout<<"请输入从0到2之间的数字。"; } if(quit) { break; }
} cout<<"程序结束"<<endl; return 0; }
|
3.2 输出结果
1 2 3 4 5 6 7 8 9 10 11
| (0)退出(1)父亲(2)儿子:1 构造father (0)退出(1)父亲(2)儿子:2 构造father 构造mother 构造son 儿子也很帅 析构son 析构mother 析构father (0)退出(1)父亲(2)儿子:
|
四 说明
- 该程序虽然能运行,但是它的缺点显而易见,父类有一个无用的虚函数beautiful(),该函数没有什么实际用途,只是为了给son类做个接口。
- 假设这个父亲生了很多儿子和女儿,那么事情就更麻烦了,每个儿子或者女儿都要在父亲类中放一个作为接口的虚函数,那么父亲类将会变得臃肿不堪。而且所有的儿子或者女儿都可以共享这些作为接口的函数,这将会严重破坏数据的封装性。
- 另外,这还将会增加了你工作的强度,因为目前你要做的是如何避免过多的儿子共享一个函数