智能指针_scoped_array:
scoped_array 很像scoped_ptr,它包装了new[]操作符(不是单纯的new)在堆上分配的动态数组,为动态数组提供了一个代理,保证可以正确地释放内存。
scoped_array 弥补了标准库中没有指向数组的智能指针的缺憾。
scoped_array 的接口和功能几乎是与scoped_ptr是相同的(甚至还要少一些),
主要特点如下:
1.构造函数接收的指针p必须是new[]的结果,而不是new表达式的结果;
2.没有*、->操作符重载,因为scoped_array持有的不是一个普通指针;
3.析构函数使用delete[]释放资源,而不是delete;
4.提供operator[]操作符重载,可以像普通数组一样用下标访问元素;
5.没有begin()、end()等类似容器的迭代器操作函数。
用法:
scoped_array 与 scoped_ptr源于相同的设计思想,故而用法非常相似:它只能在被声明的作用域内使用,不能拷贝、赋值。唯一不同的是scoped_array包装的是new[]产生的指针,并在析构时调用delete[],因为它管理的是动态数组,而不是单个动态对象。
使用:
<span style="font-size:18px;">#include <iostream>
#include <boost/smart_ptr.hpp>
using namespace std;
using namespace boost;
int main()
{
int *p = new int[10];
scoped_array<int> ps(p);
*ps = 1; //错误,没有重载 *p 和 p->
for(int i = 0; i<10;++i)
{
ps[i] = i + 1;
}
for(i = 0; i < 10; ++i)
{
cout<<ps[i]<<" ";
}
cout<<endl;
scoped_array<int> ps1;
ps1 = ps; //错误,没有重载拷贝和赋值函数
return 0;
}</span>
///////////////////////////////////////////
实现:
<span style="font-size:18px;">template <class T>
class scoped_array
{
public:
explicit scoped_array(T *p = 0):px(p)
{}
~scoped_array()
{
delete []px;
}
public:
void reset(T *p = 0)
{
this_type(p).swap(*this);
}
void swap(scoped_array &b)
{
T *tmp = b.px;
b.px = px;
px = tmp;
}
T* get()const
{
return px;
}
public:
T& operator[](int i) //重载[]
{
return px[i];
}
private:
T *px;
<span style="color:#ff0000;">//将不允许调用的函数放到私有</span>
scoped_array(scoped_array const &);
scoped_array& operator=(scoped_array const &);
typedef scoped_array<T> this_type;
void operator==(scoped_array const& )const;
void operator!=(scoped_array const& )const;
};
int main()
{
int *p = new int[10];
scoped_array<int> ps(p);
ps[3] = 1;
return 0;
}</span>