Effective C++ 随记 第二章(构造/析构/赋值运算)

类中存在构造函数、析构函数、copy函数和copy赋值操作符;

用以确保对象的初始化、摆脱旧对象并被清理、赋予对象新值。

 

条款5:了解C++默默编写并调用哪些函数

请记住:

1):编译器可以暗自为 class 创建 default构造函数、copy构造函数、 copy赋值操作符及析构函数

 

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

请记住:

1):为驳回编译器自动提供的机能,可以将响应的成员函数声明为 private 并不予实现。

 

条款7:为多态基类声明 virtual 析构函数

 Virtual 函数的实现会到组织对象的体积增加。

Virtual 析构函数的定义,可以很好的确定基类和派生类到底是哪个对象进行销毁。

 

请记住:

1):带多态性质的 base class 应该声明一个 virtual 析构函数;如果 class 带有任何 virtual 函数应该声明一个 virtual 析构函数。

2):class的设计不是为了作为 base class 使用或者不是为了具备多态性, 就不应该声明 virtual 析构函数。

 

条款8:别让异常逃离析构函数

 try{…}  // 需要异常捕捉的语句

catch(…) {  // 异常匹配

…           // 异常匹配成功执行的语句

}

 

请记住:

1):析构函数绝对不要吐出异常。如果一个被析构函数调用的函数可能抛出异常,析构函数应该捕捉任何异常,然后吞下它们(不传播)或者结束程序。

2):如果客户需要对某个操作函数运行期间的异常做出反应,那么 class 应该提供一个普通函数执行该操作,而非在析构函数中实现。

 

条款9:绝不再构造和析构函数过程中调用virtual函数

 创建 derived class 时必然会先行创建 基类。

在 base class 构造期间,调用的 virtual 函数为基类的虚函数。

 

请记住:

1):在构造和析构期间不要调用 virtual 函数,因为这类调用从不降至 derived class。

 

条款10:令 operator= 返回一个 reference to *this

请记住:

1):令赋值操作符返回一个 reference to *this

 

条款11:在 operator= 中处理“自我赋值”

请记住:

1):确保当对象自我赋值时 operator= 有良好的行为。包括比较:”来源对象“和”目标对象“的地址、精心周到的语句顺序、以及 copy-and-swap。

2):确定任何函数如果操作一个以上的对象,如果其中的多个对象时同一个对象时,其行为仍然正确。

 

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

请记住:

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

2):不要尝试以某个 coping 函数实现另一个coping 函数。应该将共同机能放进第三个函数中供以调用。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值