c – 具有不同参数类型的虚函数
我试图理解虚函数是如何工作的,我陷入了某个角色.
我写过这个小程序: class First { public: virtual void f(int a) { cout << "First!" << endl; cout << a << endl; } }; class Second : public First { public: void f(int a) { cout << "Second!" << endl; cout << a << endl; } }; void main() { Second s; First *p = &s; p->f(5); First n; p = &n; p->f(3); _getch(); } 此代码导致: Second! 5 First! 3 但是,如果我将Second :: f()函数中的int更改为其他类型,如下所示: class First { public: virtual void f(int a) { cout << "First!" << endl; cout << a << endl; } }; class Second : public First { public: void f(double a) { //double instead int here! cout << "Second!" << endl; cout << a << endl; } }; void main() { Second s; First *p = &s; p->f(5); First n; p = &n; p->f(3); _getch(); } 我的程序从不调用Second :: f(),我得到的结果如下: First! 5 First! 3 有人可以向我解释为什么会这样吗? 解决方法
当使用虚函数调度时,所谓的“最终覆盖”就是被调用的东西.对于甚至覆盖继承的虚函数的函数,它必须满足一些条件:
– ISO / IEC 14882:2001(E)§10.3(大胆强调我的) 很简单,在你的第二个例子中,Second :: f(double)的参数列表与First :: f(int)的参数列表不同,所以Second :: f(double)不是(自动)虚拟的并且不会覆盖First: :F(INT). C 11关键字覆盖声明了一个方法覆盖继承的虚方法的意图,以便编译器可以告诉您何时不这样做.例如,如果你这样做了: void f(double a) override { 编译器会给你这个诊断通知你它实际上没有覆盖任何东西,它甚至告诉你为什么它没有(“在第一个参数类型不匹配(‘int’与’double’)”): main.cpp:15:18: error: non-virtual member function marked 'override' hides virtual member function void f(double a) override { //double instead int here! ^ main.cpp:7:14: note: hidden overloaded virtual function 'First::f' declared here: type mismatch at 1st parameter ('int' vs 'double') virtual void f(int a) { ^ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |