绝不在构造和析构函数中调用 virtual 函数
2015-06-01 12:29
323 查看
看以下的这段代码,问 print调用的是基类还是派生类的版本号?
答案是 基类。。。
可能大家会非常吃惊,print不是virtual function 吗?为什么不是调用派生类的版本号呢?
首先,当定义一个派生类的对象的时候,
因为 base class 构造函数的运行更早于 derived class构造函数,
所以当 base class constructor 调用的时候,派生类的成员尚未初始化(说明,这个时候真正的 虚函数表尚未全然初始化)。
假设这个时候调用 派生类的函数(可能使用未初始化的成员)的话,必然会出现麻烦。
因此 C++ 禁止你这样做。。
事实上,在派生类对象的 base class 构造期间, 对象的类型是 bass class 而不是 derived class.
因此,虚函数调用的一定是 基类的版本号。。
相同的道理,相同适用于析构函数。
大家知道,派生类对象析构的时候,析构函数调用顺序正好与 构造函数相反:
派生类的析构函数先于基类的析构函数。
因此,在 base 析构函数调用的过程中, 编译器视其为基类对象。。
答案是 基类。。。
可能大家会非常吃惊,print不是virtual function 吗?为什么不是调用派生类的版本号呢?
首先,当定义一个派生类的对象的时候,
因为 base class 构造函数的运行更早于 derived class构造函数,
所以当 base class constructor 调用的时候,派生类的成员尚未初始化(说明,这个时候真正的 虚函数表尚未全然初始化)。
假设这个时候调用 派生类的函数(可能使用未初始化的成员)的话,必然会出现麻烦。
因此 C++ 禁止你这样做。。
事实上,在派生类对象的 base class 构造期间, 对象的类型是 bass class 而不是 derived class.
因此,虚函数调用的一定是 基类的版本号。。
相同的道理,相同适用于析构函数。
大家知道,派生类对象析构的时候,析构函数调用顺序正好与 构造函数相反:
派生类的析构函数先于基类的析构函数。
因此,在 base 析构函数调用的过程中, 编译器视其为基类对象。。
相关文章推荐
- AIX下的nmon的使用
- 3月了,春天在夏天的后面来到了
- JS正则表达式验证账号、手机号、电话和邮箱
- javascript实现设置、获取和删除Cookie的方法
- 牛人的经历
- ajax的基础
- HTML5 视频直播
- 硬件编码工具简介
- 实验三
- JS基础如何理解对象
- 控制台界面与GUI相比的优缺点
- const(每个对象中的常量), static const(类的编译时常量)
- Project Euler题解(Problem 1)
- php与html代码的若干转换
- Linux 生成SSL证书
- jQuery解析XML文件同时动态增加js文件的方法
- Durid数据池
- [LintCode] Subarray Sum & Subarray Sum II
- Spring <context:annotation-config/> 说明
- javascript基础,如何理解对象