Effective C++ 学习笔记二

Effective C++ 学习笔记二

文章目录

别让异常逃离析构函数

C++ 并不禁止析构函数吐出异常,但他不鼓励你这么做,析构函数吐出异常就会非常危险 ,总会带来过早的结束程序,或者发生不明确的行为的风险

请记住:

  1. 析构函数绝对不要吐出异常,如果一个被析构函数调用的函数可能抛出异常,析构函数应该捕捉任何异常,然后吞下他们或者结束程序。
  2. 如果客户需要对某个操作函数运行期间抛出的异常做出反映,那么class 应该提供一个普通函数执行操作。

绝不在构造和析构的过程中调用virtual函数

  1. base class 构造期间virtual函数绝对不会下降到derived classes 阶层,如果在base class 构造和析构过程中调用virtual函数会调用base class 版本的virtual函数,对于这个有一个更好的说法,由于base class的构造函数执行时 derived class 的成员变量并未初始化,如果此期间调用virtual函数下降至derived class ,要知道derived class 的函数几乎必然取用成员变量,而那些成员变量并未初始化,这将是一张通往不明确行为和彻夜调试大会串的直达车票。
    1. 根本原因:在derived class 对象的base构造期间,对象类型是base class 而不是derived class ,不只是virtual函数会被编译器解析至base class ,若使用运行期类型信息也会把对象视为base class。对象在derived class 构造函数开始执行前不会成为一个derived class对象。
  2. 相同的道理也适用于析构函数,一旦derived class 开始执行,对象内的derived class 成员变量便开始呈现未定义值,进入base class 析构函数后对象也就成为一个base class 对象。
  3. 请记住 在构造和析构期间不要调用virtual 函数,因为这类调用从不下降至derived class

令operator= 返回一个reference to *this

  1. 对了实现连锁赋值,x = y = z = 15 ,赋值操作符必须返回一个reference 指向操作符的左侧实参这是你为classes 实现赋值操作应该遵循的协议。
cpp 复制代码
Widget& operator= (const Widget& rhs){
    return* this;
}

在operator=中处理"自我赋值"

C++四种转换

相关推荐
Felicity_Gao2 小时前
uni-app VOD 与 COS 选型、开发笔记
前端·笔记·uni-app
m0_748240252 小时前
Windows编程+使用C++编写EXE加壳程序
开发语言·c++·windows
兔兔爱学习兔兔爱学习3 小时前
Spring Al学习7:ImageModel
java·学习·spring
LoveXming3 小时前
Chapter14—中介者模式
c++·microsoft·设计模式·中介者模式·开闭原则
崎岖Qiu5 小时前
【设计模式笔记06】:单一职责原则
java·笔记·设计模式·单一职责原则
江苏世纪龙科技6 小时前
新能源汽车动力系统拆装与检测实训MR软件介绍-比亚迪秦EV标准版
学习
im_AMBER6 小时前
数据结构 09 二叉树作业
数据结构·笔记·学习
杨筱毅6 小时前
【C++】【常见面试题】最简版带大小和超时限制的LRU缓存实现
c++·面试
陌路207 小时前
C23构造函数与析构函数
开发语言·c++
_OP_CHEN8 小时前
C++进阶:(二)多态的深度解析
开发语言·c++·多态·抽象类·虚函数·多态的底层原理·多态面试题