Effecive C++ 解析3

来源: 本文主要参考书籍 Effective C++ 转载请标明出处(尊重原创,谢谢!)

前面的  Effecive C++ 解析中分别:Effective C++ 解析 1 说明了条款 3 和 5  ,Effecive C++ 解析2说明条款1 和 条款2

Effecive C++ 解析3: 将介绍条款 4 和6


条款4:尽量使用 C++风格的注释

原因 1:c 风格的注释 没有 C++ 的风格的注释安全

示例 1说明:C++注释
if ( a > b ) {

 // int temp = a; // swap a and b

 // a = b;

 // b = temp;

 }

示例 2  C注释
if ( a > b ) {

 /* int temp = a; /* swap a and b */

 a = b;

 b = temp;

 */

 }

OK! 看看上面的两个小示例,应改也很清楚了吧!

原因 2:c 预处理程序不知道处理 C++风格的注释


C风格的注释当然还有它存在的价值。例如,它们在 C和C++编译器都要处理的头文件中是无法替代的。尽管如此,只要有能,你最好尽量用 C++风格的注释。值得指出的是,有些老的专门为 C写的预处理程序不知道处理 C++风格的注释,所以象下面这种情形时,事情就不象预想的那样:

  #define LIGHT_SPEED 3e8 // m/sec (in a vacuum)

 对于不熟悉C++的预处理程序来说,行尾的注释竟然成为了宏的一部分!


条款 6:析构函数里对指针成员调用 delete

原 因 :大多数情况下,执行动态内存分配的的类都在构造函数里用new分配内存,然后在析构函数里用 delete释放内存。

解决 :最初写这个类的时候当然不难做,你会记得最后对在所有构造函数里分配了内存的所有成员使用 delete。然而,这个类经过维护、升级后,情况就会变得困难了,因为对类的代码进行修改的程序员不一定就是最早写这个类的人。而增加一个指针成员意味着几乎都要进行下面的工作:

 1 :在每个构造函数里对指针进行初始化。对于一些构造函数,如果没有内存要分配给指针的话,指针要被初始化为0(即空指针)。删除现有的内存,通过赋值操作符分配给指针新的内存。

2 在析构函数里删除指针。如果在构造函数里忘了初始化某个指针,或者在赋值操作的过程中忘了处理它,问题会出现得很快,很明显,所以在实践中这两个问题不会那么折磨你。但是,如果在析构函数里没有删除指针,它不会表现出很明显的外部症状。相反,它可能只是表现为一点微小的内存泄露,并且不断增长,最后吞噬了你的地址空间,导致程序夭折。因为这种情况经常不那么引人注意,所以每增加一个指针成员到类里时一定要记清楚。

 3 另外,删除空指针是安全的(因为它什么也没做)。所以,在写构造函数,赋值操作符,或其他成员函数时,类的每个指针成员要么指向有效的内存,要么就指向空,那在你的析构函数里你就可以只用简单地delete掉他们,而不用担心他们是不是被new过。

总结:当然对本条款的使用也不要绝对。例如,你当然不会用delete去删除一个没有用new来初始化的指针,而且,就象用智能指针对象时不用劳你去删除一样,你也永远不会去删除一个传递给你的指针。换句话说,除非类成员最初用new,否则是不用在析构函数里用delete的。

 说到智能指针,这里介绍一种避免必须删除指针成员的方法,即把这些成员用智能指针对象来代替,比如C++标准库里的auto_ptr。




Effecive C++ 解析3

上一篇:Java总结 - ArrayDeque


下一篇:Docker-Context