继承noncopyable的类不能 通过拷贝构造和赋值函数操作来初始化对象;
like this:
有一个类:AA
AA aa; //OK
//1. 拷贝构造
AA bb(aa); // NO
//2. 赋值函数
AA cc;
cc = aa ;// NO
一个类的有4个基础函数:
构造函数
赋值函数
析构函数
复制构造函数
class noncopyable
的基本思想是把构造函数和析构函数设置protected权限,这样子类可以调用,但是外面的类不能调用。那么当子类需要定义构造函数的时候不至于通不过编译。
但是最关键的是noncopyable把拷贝构造和复制赋值函数做成了private,这就意味着除非子类定义自己的copy构造和赋值函数,否则在子类没有定义的情况下,外面的调用者是不能够通过赋值和copy构造等手段来产生一个新的子类对象的。
BOOST中的源码(有删减)
namespace noncopyable_ // protection from unintended AD
{
class noncopyable
{
protected:
noncopyable() {}
~noncopyable() {}
private: // emphasize the following members are private
noncopyable( const noncopyable& );
noncopyable& operator=( const noncopyable& );
};
}
typedef noncopyable_::noncopyable noncopyable;
测试类BB
class BB :public noncopyable
{
public:
BB()
{
cout << "BB" << endl;
}
}
此时在主函数中使用:
BB aa;
//1. 拷贝构造
BB bb(aa);
报错:
错误1:error C2248: “noncopyable_::noncopyable::noncopyable”: 无法访问 private 成员(在“noncopyable_::noncopyable”类中声明) ...
我们使用了拷贝构造,但是BB没有自己的拷贝构造但是爸爸有。所以找爸爸,但是爸爸又不让用!所以出错了~
赋值函数的错误同理
//2. 赋值构造
BB cc;
cc = aa;
报错:
错误 1 error C2248: “noncopyable_::noncopyable::operator =”: 无法访问 private 成员(在“noncopyable_::noncopyable”类中声明) ...
怎么才能使用拷贝构造和赋值函数呢? 自己有!!!
正所谓东西再好都是被人的,别人有不如自己有。
我们给BB加上自己的拷贝构造和赋值函数。
为了方便演示,添加一个变量、有参构造、拷贝构造。怕太乱就不写赋值函数了;
***********************************完整的BB*********************************************
class BB :public noncopyable
{
public:
BB(int n):member(n)
{
cout << "BB" << endl;
}
BB(const BB& b)
{
this->member = b.member;
cout << "拷贝构造:memeber = " << member << endl;
}
private:
int member;
};
***********************************完整的BB 结束***********************************
int main()
{
//声明一个对像aa调用构造函数, 此时aa.member = 88;
BB aa(88);
//bb调用拷贝构造,将aa.member 给了 bb, 此时bb.member 也是 88
BB bb(aa);
return 0;
}
显示结果:
赋值函数同上,就不再赘述了。
由一个简单的 noncopyable 写了这么多。
其实就2个核心问题:
1. 类的三个保护访问级别(public、protected、private )和 继承的后的访问级别的问题;
2. 构造、拷贝构造、赋值函数的调用问题,什么时候调用谁;