条款06:若不想使用编译器自动生成的函数,就该明确拒绝.
(Explicitly disallow the use of compiler-generated functions you do not want)
首先给出一个类的定义:
class HomeForSale{};
我们的目的:阻止默认复制构造函数和赋值操作符的调用,即要使以下语句无法执行:
HomeForSale h1;
HomeForSale h2;
HomeForSale h3(h1);//此处会调用默认的复构函数
h1=h2;//此处会调用赋值操作符
方法1 所有编译器产出的函数都是public,所以你可以将复构函数或者copy assignment操作符声明为private。自己声明之后阻止编译器暗自创建其专属版本,而且这些函数为private,成功阻止人们调用它。
class HomeForSale{
private:
HomeForSale(const HomeForSale& obj);//只声明不定义
HomeForSale& operator=(const HomeForSale& obj);//只声明不定义
};
方法2:
声明一个专门阻止默认复制构造函数和赋值操作符调用的基类uncopyable。
为了阻止HomeForSale类的对象被复制,我们只需要继承类uncopyable即可。
class uncopyable {
protected:
uncopyable() {}
~uncopyable() {}
private:
uncopyable(const uncopyable& obj);//只声明不定义
uncopyable& operator=(const uncopyable& obj);//只声明不定义
};
class HomeForSale :private uncopyable {};
分析:此时再执行HomeForSale h3(h1);
时,派生类默认的复制构造函数先调用基类的复制构造函数uncopyable(const uncopyable& obj);
(此时就会报错)初始化基类的成员,然后再初始化本类新增的成员。
同理,执行h1=h2;
时,首先会显式调用基类的赋值操作符uncopyable& operator=(const uncopyable& obj);
(此时也会报错)。