可能重复:
在构造函数中调用虚函数
我有一个类 Shape 及其子类 Sphere :
//Shape :
class Shape
{
public:
Shape(const string& name);
virtual ~Shape();
virtual string getName();
protected:
string mName;
};
Shape::Shape(const string& name) : mName(name)
{
/*Some stuff proper to Shape*/
/*Some stuff proper to subclass (sphere)*/
/*Some stuff proper to Shape*/
}
Shape::~Shape(){}
string Shape::getName(){ return mName; }
//Sphere :
class Sphere : public Shape
{
public:
Sphere(const string& name, const float radius);
virtual ~Sphere();
virtual string getRadius();
protected:
float mRadius;
}
Sphere::Sphere(const string& name, const float radius) : Shape(name), mRadius(radius)
{
/*Some stuff*/
}
Sphere::~Sphere(){}
float Sphere::getRadius(){ return mRadius; }
现在,如何处理 Shape 构造函数中的子类内容?我可以求助于 模板方法模式,但我将被迫在构造函数中调用纯虚函数;我试过了,编译器不喜欢它
编辑:
我选择在一个新方法“init”中移动构造函数,而虚拟方法将是“subInit”:
//Shape :
class Shape
{
public:
Shape(const string& name);
virtual ~Shape();
virtual string getName();
virtual void init();
protected:
string mName;
virtual void subInit() = 0;
};
Shape::Shape(const string& name) : mName(name){}
Shape::~Shape(){}
string Shape::getName(){ return mName; }
void Shape::init()
{
/*Some stuff proper to Shape*/
/*Some stuff proper to subclass (sphere)*/
/*Call to the pure virtual function subInit*/
subInit();
/*Some stuff proper to Shape*/
}
//Sphere :
class Sphere : public Shape
{
public:
Sphere(const string& name, const float radius);
virtual ~Sphere();
virtual string getRadius();
protected:
float mRadius;
void subInit();
}
Sphere::Sphere(const string& name, const float radius) : Shape(name),mRadius(radius)
{}
Sphere::~Sphere(){}
float Sphere::getRadius(){ return mRadius; }
Sphere::subInit()
{
/*Some stuff previously in the constructor*/
}
它基本上是模板方法模式
客户会写:
Shape* sphere = new Sphere();
sphere->init();
然后我有我的答案:在构造函数中应用这种模式是不可能的,至少在 C++ 中是这样