effective_若不想使用编译器自动生成的函数,就该明确拒绝

条款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);(此时也会报错)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值