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/

10-10 09:42