条款05:了解C++默默编写并调用哪些函数
- 如果写下:
class Empty(){ };
就好像你写下:
class Empty{
public:
Empty()=default;//default构造函数
Empty(const Empty&rhs){...}//copy构造函数
~Empty(){...}//析构函数
Empty& operator=(const Empty&rhs){...}//copy assignment操作符
};
- 内含reference成员和const成员的class必须自己定义copy assignment操作符,编译器不会帮你生成默认版本
- 如果某个base classes将copy assignment操作符声明为private,编译器将拒绝为其derived classes生成一个copy assignment操作符
请记住:
- 编译器可以暗自为class创建default构造函数,copy构造函数,copy assignment操作符,以及析构函数
条款06:若不想使用编译器自动生成的函数,就该明确拒绝
某些对象要求独一无二,不能有copy操作,可以采用将成员函数声明为private而且故意不实现它们的做法
class Widget{
public:
...
private:
...
Widget(const Widget&);
Widget&operator=(const Widget&);
};
注:因为函数不会被实现,因此写参数名称没有意义;若被friend函数或member函数调用,在编译期间不会报错
将连接期错误移至编译期可以设计一个专门阻止copying动作的base class:
class Uncopyable{
protected:
Uncopyable(){}
~Uncopyable(){}
private:
Uncopyable(const Uncopyable&);
Uncopyable&operator=(const Uncopyable&);
};
class Widget:private Uncopyable{
...
//不再声明copy构造函数或copy assign操作符
};
请记住:
- 为驳回编译器自动(暗自)提供的机能,可将相应的成员函数声明为private并且不予实现。使用像Uncopyable这样的base class也是一种做法。