C覆盖/过载问题

前端之家收集整理的这篇文章主要介绍了C覆盖/过载问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在C面临一个问题:
#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.cc
test.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 B
public:
  virtual ~B() {}
  virtual void some_func(const unsigned int& param1,const char*)
  {
    A::some_func(param1); // or fully qualify the call
  }
};

猜你在找的C&C++相关文章