Effective C++之条款12:复制对象时勿忘其每一个成分

声明:

  1. 文中内容收集整理自《Effective C++(中文版)第三版》,版权归原书所有。
  2. 本内容在作者现有能力的基础上有所删减,另加入部分作者自己的理解,有纰漏之处敬请指正。

条款12:复制对象时勿忘其每一个成分

Copy all parts of an object.

编译器对“你自己写出copying函数”的复仇行为:如果你拒绝编译器为你写出copying函数,那么当你的代码不完全时他们也不会告诉你。如给一个类新增加一个成员变量。

为class添加一个成员变量,就必须同时修改copying函数,也需要修改所有构造函数以及任何非标准形式的operator=函数。如果你忘记,编译器不太可能提醒你。

当derived class的copying函数仅仅复制了derived class的专属成员,而没有显式复制其通过继承得到的base class成员时,其base class部分会被其default构造函数初始化。

任何时候只要承担起“为derived class撰写copying函数”的责任,必须很小心地也复制其base class成分。而那些成分往往是private,所以无法直接访问它们,应该让derived class的copying函数调用相应的base class函数:

class A
{
public:
	...
	A(const A&);
	A& operator=(const A& rhs);
	...
private:
	std::string name;
}

class B: public A
{
public:
	B(const B&);
	B& operator=(const B& rhs);
private:
	int priority;
}
B::B(const B& rhs) : A(rhs), priority(rhs.priority){}

B& B::operator=(const B& rhs)
{
	A::operator=(rhs);
	priority = rhs.priority;
	return *this;
}

编写coping函数时确保:1.复制所有local成员变量;2.调用所有base classes内合适的copying函数。

不该令拷贝赋值操作符调用拷贝构造函数,也不该令拷贝赋值运算符调用拷贝构造函数。

如果发现拷贝赋值操作符和拷贝构造函数有相似的操作,可通过建立一个新的成员函数给两者调用,

请记住:
        copying函数应该确保复制对象内的所有成员变量以及所有base class成分

        不要尝试以某一个copying函数实现另一个copying函数。应该将共同机能放进第三个函数中,并由两个copying函数共同调用,这个函数往往是private而且常被命名为init。

请记住:

copying函数应该确保复制“对象内的所有成员变量”及“所有base class成分”。

不要尝试以某个copying函数实现另一个copying函数。应该将共同机制放进第三个函数中,供两个copying函数调用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值