使用计数是复制控制成员中使用的编程技术。将一个计数器与类指向的对象相关联,用于跟踪该类有多少个对象共享同一指针。创建一个单独类指向共享对象并管理使用计数。由构造函数设置共享对象的状态并将使用计算置1。每当由复制构造函数或复制操作符生成一个新副本时,使用计数加1.由析构函数撤销对象或作为赋值操作符的左操作数撤销对象时,使用计数减1。赋值操作符和析构函数检查使用计数是否已减至0,如果是,则撤销对智能指针(smart pointer)是一个行为类似指针但是提供其他功能的类。
智能指针类与实现普通指针行为区别在于:智能指针通常接受指向动态分配对象的指针并负责删除该对象。用户分配对象,但由智能指针删除它,由此智能指针需要实现复制控制成员来管理指向共享对象的指针。只要在撤销了指向共享对象的最后一个智能指针后,才能删除共享对象。使用计数是实现智能指针类最常用的方法。
所谓值类型,是指具有值语义的类,其特征:对该对象进行复制时,会得到一个不同的新副本,对原来所做的改变不会影响原有对象。
#include<iostream>
using namespace std;
class U_Ptr
{
friend class HasPtr;
int *ip;
size_t use;
U_Ptr(int *p):ip(p),use(1) {
}
~U_Ptr() { delete ip;}
};
class HasPtr {
public:
HasPtr(int *p, int i):ptr(new U_Ptr(p)), val(i) {}
HasPtr(const HasPtr &orig):ptr(orig.ptr), val(orig.val) { ++ptr->use;}
HasPtr& operator=(const HasPtr&);
int *get_ptr() const { return ptr->ip; }
int get_int() const { return val;}
void set_ptr(int *p) { ptr->ip = p;}
void set_int(int i) { val = i;}
int get_ptr_val() const { return *ptr->ip;}
void set_ptr_val(int i) { *ptr->ip = i;}
~HasPtr() {
if(--ptr->use==0)
{
delete ptr;
}
}
private:
U_Ptr *ptr;
int val;
};
HasPtr& HasPtr::operator=(const HasPtr &rhs)
{
++rhs.ptr->use;
if(--ptr->use==0)
delete ptr;
ptr=rhs.ptr;
val=rhs.val;
return *this;
}