在不实例化的情况下调用不同派生类的虚拟方法
Calling virtual methods of different derived classes without instantiating
我有以下类Hierrachy:
class Base
{
public:
virtual void DoA();
virtual void DoB();
virtual void DoC();
protected:
float m_x;
float m_y;
};
class DerivedA : public Base
{
public:
virtual void DoA() override;
virtual void DoB() override;
virtual void DoC() override;
};
class DerivedB : public Base
{
public:
virtual void DoA() override;
virtual void DoB() override;
virtual void DoC() override;
};
所有方法DoA(), DoB()
...仅在基类成员上操作,他们中的一些人可能会在其中称呼基类方法。在运行时,我将类型DerivedA
的对象作为默认值创建,但是我可能需要将其更改为DerivedB
或DerivedC
。但是,我发现通过复制DerivedA
状态并再次初始化来创建这些对象是毫无用处的。我认为解决方案可能是将DerivedA
施加到任何其他类型,但是我不确定它是否安全,是否是一个好的设计。有任何意见吗?
您给出的示例就像您正在尝试开发某种状态机,而不同的类别是不同的状态。通常使用信封是不同状态的字母/信封成语来处理这。
。#include <memory>
struct letter
{
float m_x;
float m_y;
};
class base_envelope
{
std::unique_ptr< letter > data_;
base_envelope( const base_envelope & ) = delete;
base_envelope( base_envelope && ) = delete;
public:
base_envelope(): data_() {};
base_envelope( std::unique_ptr< letter > & d ): data_(std::move(d)) {}
virtual void doA() = 0;
virtual void doB() = 0;
void swap( base_envelope & o ) { std::swap( data_, o.data_ ); }
};
class derived1: public base_envelope
{
public:
derived1(): base_envelope() {}
virtual void doA() override { }
virtual void doB() override { }
std::unique_ptr< base_envelope > change_state();
};
class derived2: public base_envelope
{
public:
derived2(): base_envelope() {}
virtual void doA() override {}
virtual void doB() override {}
std::unique_ptr< base_envelope > change_state()
{
std::unique_ptr< base_envelope > r( new derived1 );
swap( *r );
return std::move( r );
}
};
std::unique_ptr< base_envelope > derived1::change_state()
{
std::unique_ptr< base_envelope > r( new derived2 );
swap( *r );
return std::move( r );
}
您应该最好将指针指向Base
类,并在需要时创建和分配派生类的对象:
Base * p = NULL;
// some code ...
p = new DerivedA;
p->DoA(); // DoA from DerivedA class
// some code ...
p = new DerivedB;
p->DoA(); // DoA from DerivedB class
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义