类似问题已发布并已回答here和 here但建议的解决方案对我不起作用。
我有三个具有多级继承的类:
class Model
{
public:
Model();
template <typename InputModelType>
void importModel(const InputModelType &m);
virtual void process();
};
class SpecialModel : public Model
{
public:
SpecialModel();
template <typename InputModelType>
void importSpecialModel(const InputModelType &m);
virtual void process() override;
};
class SpecialSpecialModel : public SpecialModel
{
public:
SpecialModel();
template <typename InputModelType>
void importSpecialSpecialModel(const InputModelType &m);
virtual void process() override;
};
子模型是父模型的特例,可以存储在更简单的结构中,因此可以更快地处理。
我想做的是根据用户指定的输入参数 model_type
实例化模型,如下所示:
Model* model;
switch(model_type){
case 1:
model = new SpecialModel;
model->importSpecialModel(gm);
break;
case 2:
model = new SpecialSpecialModel;
model->importSpecialSpecialModel(gm);
break;
default:
model = new Model;
model->importModel(gm);
break;
}
model->process();
使用上面的代码,我得到了以下错误:
‘class Model’ has no member named ‘importSpecialModel’
‘class Model’ has no member named ‘importSpecialSpecialModel’
问题在于,导入函数是模板化的,因此在基类中将它们定义为虚函数然后在子类中覆盖是无效的。
最佳答案
您只能使用对象静态类型的函数。 您可以使用派生类型执行以下操作。
std::unique_ptr<Model> CreateModel(int model_type, const InputModelType &m)
{
switch(model_type)
{
case 1:
{
auto model = std::make_unique<PairwiseMRF>();
model->importSpecialModel(gm);
return model; // or std::move(model)
}
case 2:
{
auto model = std::make_unique<PairwiseMetricMRF>();
model->importSpecialSpecialModel(gm);
return model; // or std::move(model)
}
default:
{
auto model = std::make_unique<Model>();
model->importModel(gm);
return model;
}
}
}
然后
auto model = CreateModel(model_type, gm);
model->process();
关于c++ - 如何有条件地实例化不同的父/子类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43942657/