我目前正在编写一个复杂的类,并在其中我基本上需要复制派生类的列表。简化版本,如下所示: 我有一个基类从中我获得其他的几类:C++赋值运算符=用派生类重载
class Base
{
public:
virtual void test(void)
{
cout << "Base" << endl;
}
Base(vector<Base*> *pointer)
{
pointer->push_back(this);
}
virtual Base& operator=(const Base& rhs)
{
cout << "Base=" << endl;
return *this;
}
};
class A : public Base
{
public:
void test(void)
{
cout << "A" << endl;
}
A(vector<Base*> *pointer) : Base(pointer) {}
A& operator=(const A& rhs)
{
cout << "A=" << endl;
return *this;
}
};
class B : public Base
{
public:
void test(void)
{
cout << "B" << endl;
}
B(vector<Base*> *pointer) : Base(pointer) {}
B& operator=(const B& rhs)
{
cout << "B=" << endl;
return *this;
}
};
然后我创建对象,这是我在保存在Base类的指针列表的列表:
这些对象,然后我想在同一个班(顺序相同)第二列表复制,但它可能有不同的值。
for (int i = 0; i < (int)listA.size(); i++)
{
(*listA[i]) = (*listB[i]);
}
但是C++无法做到这一点。由于列表的类型是Base *,因此dereferencing会创建一个Base类型的对象。因此调用基类的赋值运算符=而不是从派生类中正确的。我怎样才能解决这个问题?
或者我该如何告诉C++使用正确的运算符?也许由一些isinstanceof功能?
对于全样本见:
int main()
{
vector<Base*> listA;
new Base(&listA);
new A(&listA);
new B(&listA);
vector<Base*> listB;
new Base(&listB);
new A(&listB);
new B(&listB);
for (int i = 0; i < (int)listA.size(); i++)
{
(*listA[i]).test();
}
for (int i = 0; i < (int)listA.size(); i++)
{
(*listA[i]) = (*listB[i]);
}
}
,输出:
Base
A
B
Base=
Base=
Base=
可能的重复[为什么派生类不使用基类操作符=(赋值操作符)?](http://stackoverflow.com/questions/10838211/why-doesnt-a-derived-class-use -base-class-operator-assignment-operator?rq = 1) –
将'A'分配给'B'或反之亦然是什么意思? – aschepler