不要重新定义继承而来的缺省参数值
2017-11-07 17:28
190 查看
effective c++条款37:绝不重新定义继承而来的缺省参数值
由于non-virtual函数应该绝对不被derived classes覆写,这个设定使得base中的non-virtual函数的缺省参数值不会变化,缺省参数值是静态绑定,意思是“调用一个定义与derived class内的virtual函数”的同时,却是用base class为他所制定的缺省参数值,一下为代码示例(自己写的比较粗糙):
最后附上侯老师的话:绝对不要重新定义一个继承而来的缺省参数值,因为缺省参数值都是静态绑定,而virtual函数–你唯一应该覆写的东西–却是动态绑定的。
由于non-virtual函数应该绝对不被derived classes覆写,这个设定使得base中的non-virtual函数的缺省参数值不会变化,缺省参数值是静态绑定,意思是“调用一个定义与derived class内的virtual函数”的同时,却是用base class为他所制定的缺省参数值,一下为代码示例(自己写的比较粗糙):
#include<iostream> using namespace std; class base { public: void draw(int m=2) { print(m); } private: virtual void print(int m) = 0; int m; }; class devired :public base { public: virtual void print(int m=1) { cout << "devired function"<<" "<<m; } }; void go(int m = 0) { cout << m << endl; } int main(void) { base *p = new devired; p->draw();//调用结果是输出子类print()的内容“devired function 2” system("pause"); }
最后附上侯老师的话:绝对不要重新定义一个继承而来的缺省参数值,因为缺省参数值都是静态绑定,而virtual函数–你唯一应该覆写的东西–却是动态绑定的。
相关文章推荐
- 条款38: 决不要重新定义继承而来的缺省参数值
- effective c++ 条款38: 决不要重新定义继承而来的缺省参数值
- 关于C++虚函数默认参数的问题。Effective C++ 条款38: 决不要重新定义继承而来的缺省参数值
- 不要重新定义继承而来的缺省参数值
- 决不要重新定义继承而来的缺省参数值
- effective C++笔记之条款38: 绝不要重新定义继承而来的缺省参数值
- 条款38: 决不要重新定义继承而来的缺省参数值(有味道的一条)
- C++ 绝不要重新定义继承而来的缺省参数值
- 决不要重新定义继承而来的缺省参数值
- 条款37 绝不要重新定义继承而来的缺省参数值
- 决不要重新定义继承而来的缺省参数值
- 绝不要重新定义继承而来的缺省参数值(Effective C++_37)
- effective c++ 条款37: 决不要重新定义继承而来的非虚函数
- 条款37:绝不重新定义继承而来的缺省参数值
- Effective C++条款 37:绝不重新定义继承而来的缺省参数值
- C++决不要重新定义继承而来的非虚函数
- 绝对不要重新定义继承而来的non-virtual函数(Effective C++_36)
- 读书笔记 effective c++ Item 36 永远不要重新定义继承而来的非虚函数
- 【37】绝不重新定义继承而来的缺省参数值
- Effective C++条款 37:绝不重新定义继承而来的缺省参数值