您的位置:首页 > 其它

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

2014-05-23 13:04 281 查看
条款6:若不想使用编译器自动生成的函数,就该明确拒绝

书中采用房子对象来说明,一套房子是一个独一无二的资源,是不能拷贝第二个。
class HouseForSale
{

};

HouseForSale h1;
HouseForSale h2;
HouseForSale h3(h1); //调用默认拷贝构造函数
h2 = h1;  //调用默认拷贝赋值函数</span>
因此在这样的类中不能阻止房子进行拷贝和复制,那该如何防止?声明私用的拷贝构造函数和拷贝赋值函数,并且不用定义它。
于是将房子改成下面这样
class HouseForSale
{
private:
HouseForSale(const HouseForSale &);
HouseForSale &operator = (const HouseForSale &);
};
只有声明拷贝构造函数和拷贝赋值函数,而且不需要参数名,再调用时就编译错误,但这个不能保证类中的成员函数和友元函数调用它,不过虽然调用了,编译没有错误,链接时会出错,因为没有定义。那如何将错误提升到编译阶段?
在书中定义一个基类
class Uncopyable
{
protected:
Uncopyable() {};
~Uncopyable() {};
private:
Uncopyable(const Uncopyable &);
Uncopyable & operator = (const Uncopyable &);
};
我们唯一做的就是继承他,且不用再声明拷贝构造函数和拷贝赋值函数
class HouseForSale : private Uncopyable
{

}
这样定义类后,只有视图对HouseForSale对象进行拷贝,编译器就会自动生成拷贝构造函数和赋值函数,这些函数的“编译器生成版“会尝试调用其base class的对应兄弟,那些调用会被编译器拒绝,因为其base
class的拷贝函数是private。

记住:
为驳回编译器自动(暗自)提供的机能,可以将相应的成员函数声明为private并且不予实现。使用像Uncopyable这样的base class也是一种做法。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐