考虑一个地产中介, 他售卖的商品是房子, 中介软件系统会有一个class来描述所售的房屋:
class HomeForSale {...}
如果说每一套房子都是不同的,我们为这个类的对象做一份副本就没有意义,所以你希望对这个类对象的拷贝会失败:
HomeForSale h1;
HomeForSale h2;
HomeForSale h3(h1);
h1 = h2;
如果是普通的函数, 你只需要不声明这个函数, 就不会有被调用的风险, 而构造函数和拷贝构造函数则不同, 如果不声明, 则编译器会帮助我们生成一个默认的函数。
当前的一个方法是, 将构造函数声明为private的函数并且只声明而不定义, 防止member函数和friend函数调用他们,
class HomeForSale
{
private:
HomeForSale(const HomeForSale&);
HomeForSale& operator=(const HomeForSale&);
};
如果当member函数或者friend函数试图去调用拷贝构造函数, 连接器会提示错误(找不到函数的实现),根据错误越早出现约好的原则,如果我们希望让错误在编译期间出现,则可以声明一个base class, 将拷贝构造函数和= 运算符重载在base class中声明为private, 然后再让HomeForSale继承于base class.
class Uncopyable
{
protected:
Uncopyable(){}
~Uncopyable(){}
private:
Uncopyable(const Uncopyable&);
Uncopyable& operator=(const Uncopyable&);
};
当有人希望拷贝HomeForSale的对象时, 父类的对应函数会被调用, 因其是private的,所以调用会失败。
|