#include <iostream>class A{protected: voID some_func(const unsigned int& param1) { std::cout << "A::some_func(" << param1 << ")" << std::endl; }public: virtual ~A() {} virtual voID some_func(const unsigned int& param1,const char*) { some_func(param1); }};class B : public A{public: virtual ~B() {} virtual voID some_func(const unsigned int& param1,const char*) { some_func(param1); }};int main(int,char**){ A* t = new B(); t->some_func(21,"some char*"); return 0;}
我正在使用g 4.0.1和编译错误:
$g++ -W -Wall -Werror test.cctest.cc: In member function ‘virtual voID B::some_func(const unsigned int&,const char*)’:test.cc:24: error: no matching function for call to ‘B::some_func(const unsigned int&)’test.cc:22: note: candIDates are: virtual voID B::some_func(const unsigned int&,const char*)
为什么我必须指定B类中some_func(param1)的调用是A :: some_func(param1)?它是g的BUG还是来自g的随机消息,以防止我看不到的特殊情况?
解决方法 问题是在派生类中,您将隐藏受保护的方法在基类中.您可以执行以下 *** 作:要么完全限定派生对象中的受保护方法,要么使用using指令将该方法带入范围:class B : public A{protected: using A::some_func; // bring A::some_func overloads into Bpublic: virtual ~B() {} virtual voID some_func(const unsigned int& param1,const char*) { A::some_func(param1); // or fully qualify the call }};总结
以上是内存溢出为你收集整理的C覆盖/过载问题全部内容,希望文章能够帮你解决C覆盖/过载问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)