Effective C++条款36解读: 绝不重新定义继承而来的non-virtual函数
来源:互联网 发布:全景地图制作软件 编辑:程序博客网 时间:2024/06/08 19:32
我们来看看这样一个简单的程序:
#include <iostream>#include <string>using namespace std;class A{public:void fun(){cout << "A" << endl;}};class B : public A{public:void fun(){cout << "B" << endl;}};int main(){B b;A *p1 = &b;p1->fun(); // AB *p2 = &b;p2->fun(); // Breturn 0;}稍微懂点C++的人都知道, 上述程序的结果为:
A
B
对于同一个&b, 得到的结果不一样, B类的fun函数实际上隐藏了A类的fun函数, 颇有点精神分裂的感觉。 实际上, 这也是一个设计上的错误, 如果B的fun函数真要表现得与A不一致, 那应该把A的fun函数声明为virtual函数啊。
鉴于重新定义继承而来的non-virtual函数会产生不易理解的结果, 也确实没有必要这么搞, 所以, 绝不重新定义继承而来的non-virtual函数, 不过, 笔试面试题目中肯定有这样的“流氓”代码。
0 0
- Effective C++条款36解读: 绝不重新定义继承而来的non-virtual函数
- Effective C++:条款36:绝不重新定义继承而来的non-virtual函数
- 读书笔记《Effective C++》条款36:绝不重新定义继承而来的non-virtual函数
- Effective C++ 读书笔记 条款36:绝不重新定义继承而来的 non-virtual 函数
- Effective C++ 条款36:绝不重新定义继承而来的non-virtual函数
- 《Effective C++》36:绝不重新定义继承而来的non-virtual函数
- C++之绝不重新定义继承而来的non-virtual函数(36)---《Effective C++》
- 《Effective C++》读书笔记之item36:绝不重新定义继承而来的non-virtual函数
- 条款36:绝不重新定义继承而来的non-virtual函数
- 条款36-37绝不重新定义继承而来的non-virtual函数与缺省参数
- 条款36:绝不重新定义继承而来的non-virtual函数
- Effective C++ Item 36 绝不重新定义继承而来的 non-virtual 函数
- 绝不重新定义继承而来的non-virtual函数
- 条款36:绝不重定义继承而来的non-virtual函数
- 绝对不要重新定义继承而来的non-virtual函数(Effective C++_36)
- 条款36:绝对不要重新定义继承而来的non-virtual函数
- 条款36:决不重新定义继承而来的non-virtual函数
- 条款36:绝对不要重新定义继承而来的non-virtual函数
- C++处理异常 try,catch,throw
- MySQL my.cnf参数配置优化详解
- C++11 Tutorial: Introducing the Move Constructor and the Move Assignment Operator
- Extern "C"的作用解析
- Mysql视图
- Effective C++条款36解读: 绝不重新定义继承而来的non-virtual函数
- 剑指offer 面试题3
- Google Java编程风格指南
- 基于VMware的网络配置
- 第十五周oj刷题——Problem F: C++习题 商品销售
- Java Card Applet Development——环境搭建及基础概念
- java中String.intern() 方法到底是干啥的?
- linux-常用命令-待续
- 由进程名获取进程ID及其主线程ID