如何在C++中使用override关键字进行多重泛型继承
How do I use the override keyword for multiple generic inheritance in C++?
我有一个通用的IDetachable接口,它提供了一种方法:
template<class T>
class IDetachable {
public:
virtual T detached() const = 0;
};
我有以下示例类:
class A: public IDetachable<A> {
virtual A detached() const override {
// some implementation which returns a detached A object
}
};
继承B:时出现问题
class B: public A, public IDetachable<B> {
virtual B detached() const override {
// some implementation which returns a detached B object
}
};
叮当++告诉我:
error: virtual function 'detached' has a different return type ('B')
than the function it overrides (which has return type 'A')
在我看来,编译器自动为override关键字选择了第一个父项。有没有机会告诉编译器我打算用override关键字继承哪个父方法?
问题不在于如何重写其中一个,而在于不能有两个具有相同签名和不同返回类型的函数。
考虑:
template<class T, class U>
class IDetachable {
public:
virtual ~IDetachable() {}
virtual T detached() const = 0;
virtual U detached() const = 0; // whoopse problem
};
两个相同的签名函数如何返回不同的类型并不重要——这总是非法的。
@AdrianMay提供了一个有效的答案。他更改了函数的签名。
您可以传递一个伪T来分离:
template<class T>
class IDetachable {
public:
virtual T detached(T*dummy) const = 0;
};
你忽略了这个参数,但现在你可以专门研究它了。
您只想要返回类型协方差吗?它只适用于指针和引用:
template<class T>
class IDetachable {
public:
virtual T* detached() const = 0;
};
class A: public IDetachable<A> {
virtual A* detached() const override {
// some implementation which returns a detached A object
}
};
class B: public A, public IDetachable<B> {
virtual B* detached() const override {
// some implementation which returns a detached B object
}
};
int main() {
IDetachable<A> *da = new A;
A *a = da->detached();
IDetachable<B> *db = new B;
B *b = db->detached();
}
相关文章:
- 错误处理.将系统错误代码映射到泛型
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 链表的泛型函数remove()与成员函数remove)
- 如何编写将要继承的泛型代码?
- 继承泛型成员函数
- 继承类中没有匹配的泛型委托作为 lambda 参数
- 泛型继承将超级数据字段更改为常量 [来自硬件]
- C++泛型编程 CRTP 基类继承自派生类型提供的类
- 从一个基类的指针对另一个基类的多重继承和泛型访问
- 如何在C++中使用override关键字进行多重泛型继承
- 泛型继承和重载运算符+
- 无法调用继承的受保护泛型类成员
- 继承和虚函数与泛型编程
- 泛型树类的继承
- 多重继承和泛型程序
- OOP设计——从泛型容器继承
- c++,通过指针传递泛型数组,继承,错误:没有接受右操作数的操作符
- 为什么需要模板/泛型?继承还不够吗?
- 对泛型函数使用继承
- 泛型继承和复制构造函数