【BOOST】boost : : noncopyable 分析,拷贝构造、赋值函数
2017-08-12 11:01
615 查看
继承noncopyable的类不能 通过拷贝构造和赋值函数操作来初始化对象;
like this:
一个类的有4个基础函数:
构造函数
赋值函数
析构函数
复制构造函数
但是最关键的是noncopyable把拷贝构造和复制赋值函数做成了private,这就意味着除非子类定义自己的copy构造和赋值函数,否则在子类没有定义的情况下,外面的调用者是不能够通过赋值和copy构造等手段来产生一个新的子类对象的。
BOOST中的源码(有删减)
测试类BB
此时在主函数中使用:
报错:
我们使用了拷贝构造,但是BB没有自己的拷贝构造但是爸爸有。所以找爸爸,但是爸爸又不让用!所以出错了~
赋值函数的错误同理
报错:
怎么才能使用拷贝构造和赋值函数呢? 自己有!!!
正所谓东西再好都是被人的,别人有不如自己有。
我们给BB加上自己的拷贝构造和赋值函数。
为了方便演示,添加一个变量、有参构造、拷贝构造。怕太乱就不写赋值函数了;
[b]***********************************[/b]完整的BB*********************************************
[b]***********************************[/b]完整的BB 结束[b]***********************************[/b]
显示结果:
赋值函数同上,就不再赘述了。
由一个简单的 noncopyable 写了这么多。
其实就2个核心问题:
1. 类的三个保护访问级别(public、protected、private )和 继承的后的访问级别的问题;
2. 构造、拷贝构造、赋值函数的调用问题,什么时候调用谁;
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;< 4000 /code>
测试类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加上自己的拷贝构造和赋值函数。
为了方便演示,添加一个变量、有参构造、拷贝构造。怕太乱就不写赋值函数了;
[b]***********************************[/b]完整的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; };
[b]***********************************[/b]完整的BB 结束[b]***********************************[/b]
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. 构造、拷贝构造、赋值函数的调用问题,什么时候调用谁;
相关文章推荐
- 私有继承于Noncopyable,屏蔽默认拷贝构造与默认复制构造
- boost noncopyable实现禁止类拷贝
- boost noncopyable实现禁止类拷贝
- boost::noncopyable 禁止拷贝
- boost::noncopyable 分析
- boost noncopyable
- 深入C++的拷贝构造和赋值函数 (深拷贝,浅拷贝)
- boost noncopyable
- vector的push_back拷贝构造和空间占用分析
- 【Boost】boost::noncopyable介绍
- boost noncopyable
- Boost 实用工具:noncopyable、BOOST_BINARY宏、BOOST_CURRENT_FUNCTION宏、bitset类型
- boost/noncopyable.hpp
- c++ boost学习之noncopyable
- 【Boost】boost::noncopyable介绍 .
- boost noncopyable实现禁止类拷贝
- boost::noncopyable介绍
- 先来理解boost::noncopyable[1-1]
- 无法访问 private 成员(在“boost::asio::detail::noncopyable”类中声明)
- 【Boost】boost::noncopyable介绍