无效的协变返回类型,嵌套类c ++

问题描述 投票:3回答:1

我有一个第一个类A,它包含一个带有虚方法的迭代器嵌套类:

template <typename T >
class A {
  public:
      class iterator {
      public:
          virtual ~iterator() {};
          virtual T& operator++();
       };

      virtual iterator begin() const = 0;
};

我有第二个B类,它覆盖虚拟方法:

template <typename T >
class B : public A<T> {
   public:
      class iterator : A<T>::iterator {
          T& operator++() override { 
              iterator p(*this);
              return p; //for exemple
          }
      };

   iterator begin() const override {
       return iterator(this);// for exemple 
   } 
};

但是当我使用B类时:

B<int> test;

我有这样的东西,编译错误:

error: invalid covariant return type for 'B<T>::iterator B<T>::begin() const [with T = int]'
error:  overriding 'B<T>::iterator V<T>::begin() const [with T = int]'

如何在B类中实现迭代器?

c++ virtual covariance covariant-return-types
1个回答
6
投票

根据[class.virtual]/8,共变量返回类型有一些它们需要满足的约束。

重写函数的返回类型应与重写函数的返回类型相同,或者与函数类的协变相同。如果函数D :: f覆盖函数B :: f,则函数的返回类型如果满足以下条件则是协变的:

  • 两者都是类的指针,都是对类的左值引用,或者两者都是对类的右值引用
  • 返回类型B :: f中的类与D :: f的返回类型中的类相同,或者是D ::的返回类型中类的明确且可访问的直接或间接基类。 F
  • [...]

您的公开内容不会继承,因此无法访问该基础。而且你没有返回指针或引用。

返回具有值语义的类型是好的!你不应该放弃这一点。您可以使用pimpl习语替换co-variant返回类型的尝试。让iterator通过指针管理多态“迭代器实现”类。

© www.soinside.com 2019 - 2024. All rights reserved.