为具有不同签名的函数的派生类设计基类
Design base class for derived classes with functions having different signatures
class B {
public:
virtual void foo(?);
}
class D1 : public B {
public:
void foo(T1*);
}
class D2 : public B {
public:
void foo(T2*);
}
B* b1 = new D1();
B* b2 = new D2();
T1 和 T2 可能无关。
如何设计类,以便称为 b1 和 b2 调用具有正确类型的正确 foo?
最多可以使用 c++14。
您希望它执行的方式可以通过以下代码实现,但在我看来不是一个好的设计。因此,您需要重新考虑您的设计。
class T1 {
public:
void f() {
cout << "Calls T1::fn";
}
};
class T2 {
public:
void g() {
cout << "Calls T2::gn";
}
};
class B {
public:
virtual ~B() {}
virtual void foo(T1* t) {/* throw some exception maybe! */}
virtual void foo(T2* t) {/* throw some exception maybe! */}
};
class D1 : public B {
public:
void foo(T1* t) {
t->f();
}
};
class D2 : public B {
public:
void foo(T2* t) {
t->g();
}
};
现场演示!
class B {
public:
template<class Derived, class T>
void foo(T &&x) {
//Crashes if can't be converted, test for nullptr maybe
dynamic_cast<Derived*>(this)->foo(x);
}
}
class D1 : public B<D1> {
public:
void foo(T1*);
}
class D2 : public B<D2> {
public:
void foo(T2*);
}
B * b1 = new D1();
B * b2 = new D2();
T1 t1;
b1->foo<D1> (&t1);
由于T1
和T2
没有关系,也不属于同一个类树,那么这意味着在调用foo
时,你知道B
b1
属于哪个子类。因此,您只需将该子类作为模板参数即可。
另一种解决方案是将 C 样式转换为 void*
:(C++ 中不建议)
class B {
public:
template<class T>
void foo(T *x) {
foo_handler(reinterpret_cast<void*>(x));
}
protected:
virtual void foo_handler(void*) = 0;
}
class D1 : public B<D1> {
public:
void foo(T1*);
private:
void foo_handler(void *x) {foo(reinterpret_cast<T1*>(x));}
}
class D2 : public B<D2> {
public:
void foo(T2*);
private:
void foo_handler(void *x) {foo(reinterpret_cast<T2*>(x));}
}
B * b1 = new D1();
B * b2 = new D2();
T1 t1;
b1->foo(&t1);
相关文章:
- 在派生函数中指定void*参数
- 使用 std::variant<...时调用 BaseState 函数而不是派生函数>
- 从基类数组调用派生函数
- 我设计了一个类并创建了基指针,但是当我尝试通过基指针访问派生函数时,它会出错
- c++ 在派生函数中启动 OMP 线程
- 派生函数的映射
- NIST SP 800-56A 串联/单步密钥派生函数的现有实现
- C++从基类实例调用派生函数
- c++多态性-使用基指针访问派生函数
- 派生函数中的NULL实现
- 与派生函数参数绑定
- 从基类派生函数
- 继承和使用派生函数
- 在列表对象中使用对象的派生函数
- 当派生函数定义了析构函数时,使用复制函数而不是移动函数
- 使用基类的派生函数
- 为什么调用基类函数而不是派生函数
- 多重继承派生类:如何在不重复调用 base 的情况下重用派生函数
- 试图与 Base 中的派生函数交朋友 - 为什么它不起作用?
- 在继续派生函数之前先执行基函数