条款14:在资源管理类中小心copying行为

RAII对象被复制时的几种选择:(前两种最常用)

  1. 禁止复制
class A:private Uncopyable{...};
  1. 引用计数,复制时将资源的“被引用数”递增。RAIIclass包含一个shared_ptr成员变量即可。shared_ptr可以定制删除器,即当引用为0时触发。
class Lock{
public:
	explict Lock(Mutex* pm):mutexPtr(pm, unlock)
	{
		lock(mutexPtr.get());
	}
	//不必声明析构函数,
	//析构函数,不论是编译器生成的还是用户自定的
	//都会自动调用其non-static成员变量的析构函数。
	//mtexPtr会在引用计数为0时自动调用unlock
private:
	shared_ptr<Mutex> mutexPtr;//使用shared_ptr替换raw pointer
};
  1. 深度复制
  2. 转移底部资源的所有权
    希望确保永远只有一个RAII对象指向原始资源,即使RAII对象被复制依然如此。auto_ptr.

默认copying函数可能不会满足要求,你得自己编写它们。

猜你喜欢

转载自blog.csdn.net/lzhtcsw2016/article/details/88412640