为什么这个拷贝构造函数不起作用?

Rag*_*hav 1 c++ oop class

g ++说调用(Order)(Order&)没有匹配,当它涉及主程序中调用order的复制构造函数的一行时.

Order.h-它包含类顺序

class Order
{

private:

int orderNo;



public:

Order()
{}

//Copy Constructor
Order(Order &o)
{
    orderNo = o.putOrderNo();
}

Order(int i)
{
    orderNo = i;
}

};
Run Code Online (Sandbox Code Playgroud)

错误代码在主文件中 -

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.
}     
Run Code Online (Sandbox Code Playgroud)

编译器拒绝接受"CurrentOrder(o)"行,它将o的详细信息复制到名为CurrentOrder的Order类的另一个对象中.我是否必须重载=运算符或是否有另一种方法来克服这个问题?

编辑

这段代码已经过时了,我已经解决了这个问题,而且我还重写了这个和其他代码,所以我现在有一些新的,我很快就会问!

Pet*_*ker 9

复制构造函数构造一个新对象.既然CurrentOrder已经存在,再次构建它CurrentOrder(o)是没有意义的:没有意义.要指定oCurrentOrder使用分配:CurrentOrder = o;.