摘要: 1. 条款13导入RAII的观念:资源获取时机便是初始化时机,资源会在不需要的时刻被销毁,典型代表就是shared_ptr和weak_ptr,但是并非所有资源都是堆内存,例如外存和堆栈,在这种情况下,auto_ptr,shared_ptr,weak_ptr显然不适合作为资源管理类,这就需要建立自己的... 阅读全文
posted @ 2015-08-22 21:42 Reasno 阅读(233) 评论(0) 推荐(0) 编辑
摘要: 1. 在使用堆内存时,需要手动delete指针以防内存泄露,但是有些例外情况(例如发生异常)会使得内存资源无法释放,此外,使用者也极有可能忘记释放堆内存,因此需要"以对象管理资源",也就是把资源放进对象内,用析构函数来确保资源被释放,这种思想被称为"资源取得时机就是初始化时机"(Resource A... 阅读全文
posted @ 2015-08-22 20:51 Reasno 阅读(472) 评论(0) 推荐(0) 编辑
摘要: (转载自http://www.zhihu.com/question/32422838 作者李昭鸿)终有一天我手中的编译器将成为我灵魂的一部分,这世界在我的眼中将被代码重构,我将看到山川无尽银河无垠都汇成二进制的数字河流,过往英雄都在我脑海眼前一一浮现,而我听到无数码农跪倒在我的程序面前呼喊。他们叫... 阅读全文
posted @ 2015-08-22 17:46 Reasno 阅读(168) 评论(0) 推荐(0) 编辑
摘要: 1. 编译器合成的拷贝构造函数默认调用基类的拷贝构造函数,合成的拷贝构造操作符也是一样.2. 对于自己编写的拷贝构造函数,编译器不再默认调用基类的拷贝构造函数,仅在拷贝构造函数中没有初始化基类部分时调用默认构造函数.对于自己编写的拷贝赋值操作符,编译器不额外作任何操作(即使类的编写者忘记调用基类的拷... 阅读全文
posted @ 2015-08-22 16:46 Reasno 阅读(154) 评论(0) 推荐(0) 编辑
摘要: 1. 为了支持形如“a=b=c”的连锁形式,最好令operator=返回一个reference to *this.2. 如果类中含有用于指向堆内存的指针,那么赋值操作符就要注意自我赋值的问题,例如:class A{public: ... A& operator=(const A& tmp... 阅读全文
posted @ 2015-08-22 15:08 Reasno 阅读(275) 评论(0) 推荐(0) 编辑
摘要: 1. 在一个继承体系中,最底层的派生类在构造过程中,先初始化基类部分,再按继承层次依次初始化派生类部分,因此被构造的对象先作为一个基类对象,再按继承层次依次成为派生类对象,例如,在继承层次A→B→C→D中,构造一个D类对象,其依次经历了A→B→C→D的转变,因此对于以下代码:#include usi... 阅读全文
posted @ 2015-08-22 15:04 Reasno 阅读(230) 评论(0) 推荐(0) 编辑
摘要: 1. 当异常发生时,如果异常发生在一个try块内部,程序就会跳出该try块,并逐层寻找匹配的catch,跳出try块的过程中,会销毁该try内创建的对象并调用析构函数,如果调用析构函数的过程中又发生异常,程序就会调用标准库terminate函数(terminate函数调用abort函数)结束执行,例... 阅读全文
posted @ 2015-08-22 11:09 Reasno 阅读(575) 评论(0) 推荐(0) 编辑