构造函数和虚函数

 1 class B
 2 {
 3 public:
 4     //在构造函数中调用f()虚函数;
 5     B() { this->f(); };
 6     virtual void f() { cout << "Executing B::f()" << endl; };
 7 
 8 };
 9 
10 
11 class D:public B
12 {
13 public:
14     D() {};//自动调用B::B();
15     virtual void f() { cout << "Executing D::f()" << endl; };
16 };
17 
18 void main()
19 {
20     D d;
21     cout << "Object d was created successfully." << endl;
22     d.f();//调用虚函数
23 }

结果输出:
 Executing B::f();

 Object d was created successfully

 Executing D::f()

 

原因:
因为在D完全创建之前,B已经被创建。

所以先调用B的f();

D创建完后,根据动态性调用D的f();

 

一般和特殊的关系:

像TPerson中的Print()虚函数属于一般的,因为每个他的派生类都可以调用,产生相同的结果;

但是在派生类中再次对Print()进行了实现,那么这个函数就变得特殊了;

转载于:https://www.cnblogs.com/zhengzhe/p/6600618.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值