如果不声明copy ctor和copy assignment,编译器会自动声明,并且都是public的。如何阻止copying呢?
1. 将成员函数声明为private而且故意不去实现它
c++标准库的iostream程序中就是这样做的。ios_base, basic_ios和sentry类无一例外。我查看了安装Dev c++时候安装的编译器gnu c++的源代码,如下:
这样,如果拷贝该类对象,编译器会阻止;如果不慎在member函数或friend函数调用,链接器会抱怨。
另外,我们知道,把连接期错误移到编译器很好(愈早查出错误肯定愈好),第1种方式改进之。
2. 专门设计一个base类
这个基类不含任何数据,具体实现:
class Uncopyable {
protected:
Uncopyable() {}
~Uncopyable() {} // 允许derived class构造和析构
private:
Uncopyable(const Uncopyable&);
Uncopyable& operator=(const Uncopyable&);
};
// 为了阻止example类对象被拷贝,只需继承Uncopyable类
class example : private Uncopyable {
... // 该类不再声明copy ctor和copy assignment
};
任何尝试拷贝example类对象的行为,compiler都会自动生成一个copy ctor和copy assign. 而这些编译器生成版会尝试调用base class的对应兄弟,而base class中的拷贝函数是private的,所以编译出错。
3. Boost库提供的noncopyable类
其实就是第2点。
总结:为了驳回compiler自动提供的机能,可将相应的成员函数声明为private并且不予实现。使用想Uncopyable这样的base class也是一种做法。