g++表示,在主程序中调用order的copy构造函数的一行中,调用(Order)(Order&)没有匹配项。
Order.h-包含类order
class Order
{
private:
int orderNo;
public:
Order()
{}
//Copy Constructor
Order(Order &o)
{
orderNo = o.putOrderNo();
}
Order(int i)
{
orderNo = i;
}
};
错误代码在主文件中-
bool setCurrentOrder(Order o)
{
CurrentOrder(o); //currentOrder is a global var defined elsewhere.
//after this, there are some comparisons to determine
//whether the object was copied, then true or false is returned.
}
编译器拒绝接受“CurrentOrder(o)”行,该行将o的详细信息复制到Order类的另一个对象CurrentOrder中。
我是否必须重载=运算符,还是有另一种方法可以克服这个问题?
编辑
这段代码已经过时,我已经解决了这个问题,并且还对这个代码和其他代码进行了修改,因此我现在有一些新代码,我将在不久后询问!
最佳答案
复制构造函数构造一个新对象。由于CurrentOrder
已经存在,因此再次构造它是没有意义的:CurrentOrder(o)
是没有意义的。要将的o
的值分配给CurrentOrder
,请使用CurrentOrder = o;
。
关于c++ - 为什么此复制构造函数不起作用?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34473907/