我有一个第一个类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类中实现迭代器?
根据[class.virtual]/8,共变量返回类型有一些它们需要满足的约束。
重写函数的返回类型应与重写函数的返回类型相同,或者与函数类的协变相同。如果函数D :: f覆盖函数B :: f,则函数的返回类型如果满足以下条件则是协变的:
- 两者都是类的指针,都是对类的左值引用,或者两者都是对类的右值引用
- 返回类型B :: f中的类与D :: f的返回类型中的类相同,或者是D ::的返回类型中类的明确且可访问的直接或间接基类。 F
- [...]
您的公开内容不会继承,因此无法访问该基础。而且你没有返回指针或引用。
返回具有值语义的类型是好的!你不应该放弃这一点。您可以使用pimpl习语替换co-variant返回类型的尝试。让iterator
通过指针管理多态“迭代器实现”类。