effective C++ 3th 备忘1

2014-11-21 星期五 22:00:15 
1、copy构造/copy赋值

copy构造函数被用来"以同型对象初始化自我对象", 

copy assignment操作符被用来"从另一个同型对象中拷贝其值到自我对象"

1
2
3
4
5
6
7
8
9
10
11
class  Widget
{
public :
     Widget();                    //default构造函数
     Widget(constWidget&rhs);     //copy构造函数
     Widget&operator=(constWidget&rhs);   //copy assignment操作符
};
 
Widget w1;
Widget w2(w1);
w1 = w2;
2、尽量以canst, enum,inline替换#define

//以a和b的较大值调用f

#defineCALLWITHMAX(a, b) f ((a) > (b) ? (a) : (b))

int a =5, b =0;

CALLW工TH MAX(++a, b);//a被累加二次

CALLWITHMAX(++a, b+l0);//a被累加一次

在这里,调用f之前,a的递增次数竟然取决于"它被拿来和谁比较"!

3、尽可能使用const
4、条款06: 若不想使用编译器自动生成的函数,就该明确拒绝
  • 主要关心 copy构造函数 和 copy assignment。

  • 所有编译器产出的函数都是public,因此你可以将copy构造函数或copyassignment操作符声明为private。

  • member函数和friend函数还是可以调用你的private 函数,可以通过只声明不定义来避免他们调用(linkage error)。

  • "将成员函数声明为private而且故意不实现它们"这一伎俩是如此为大家接受,因而被用在C++ iostrearn程序库中阻止copying行为。

参考 class HomeForSale:private Uncopyable{}


5、条款07: 为多态基类声明virtual析构函数

如果你曾经企图继承一个标准容器或任何其他"带有non-virtual析构函数"的class,拒绝诱惑吧! (很不幸C++没有提供类似Java的final classes或C# 的sealedclasses那样的"禁止

派生"机制。)

"给base classes一个virtual析构函数",这个规则只适用于polymorphic(带多态性质的)base classes身上。这种base classes的设计目的是为了用来"通过base class接口处理derived class对象"。(is a)

Uncopyable和标准程序库的input iterator tag (条款47) ,它们并非被设计用来"经由base class接口处置derivedclass对象",因此它们不需要virtual析构函数。(has a)

  • polymorphic (带多态性质的)base classes应该声明一个virtual析构函数。如果class带有任何virtual函数,它就应该拥有一个virtual析构函数。

  • Classes 的设计目的如果不是作为base classes 使用,或不是为了具备多态性(polymorphically) ,就不该声明virtual析构函数。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值