前言
作用域指针对应的类名为boost::scoped_ptr,定义在boost/scoped_ptr.hpp中。
一个作用域指针独占一个动态分配的对象。
一旦用一个地址来初始化,这个动态分配的对象将在析构阶段释放。
与std::auto_ptr比较
1、因为一个作用域指针只是简单保存和独占一个内存地址,所以boost/scoped_ptr的实现比std::auto_ptr简单。
2、作用域指针不能传递它所包含对象的所有权到另一个作用域指针,所以可以避免不经意间的所有权传递,在不需要所有权传递的时候应该优先使用boost::scoped_ptr。
#include <iostream>
#include <boost\scoped_ptr.hpp>
using namespace std;
int main()
{
boost::scoped_ptr<int> i(new int);
*i = 1;
cout << "*i = " << *i << endl; //operator*() 取对象内容
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
*i.get() = 2;
cout << "*i = " << *i << endl; //operator*() 取对象内容
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
i.reset(new int); //用一个新的对象重新初始化智能指针
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
system("pause");
return 0;
}
#include <iostream>
#include <boost\scoped_ptr.hpp>
using namespace std;
int main()
{
boost::scoped_ptr<int> i(new int);
*i = 1;
cout << "*i = " << *i << endl; //operator*() 取对象内容
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
*i.get() = 2;
cout << "*i = " << *i << endl; //operator*() 取对象内容
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
i.reset(new int); //用一个新的对象重新初始化智能指针
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
system("pause");
return 0;
}
运行结果
注意点
boost::scoped_ptr 的析构函数使用delete操作符来释放所包含的对象,所以boost::scoped_ptr不能使用动态分配的数组来初始化,因为这需要delete[ ] 来释放。这种情况,可以使用boost::scoped_array类。
作用域数组
作用域数组类名为 boost::scoped_array,定义在 boost/scoped_array.hpp 中。
作用域数组只能用于数组对象,必须通过动态分配的数组来初始化。
作用域数组的析构函数使用 delete[] 操作符来释放所包含的对象。
#include <iostream>
#include <boost\scoped_array.hpp>
using namespace std;
int main()
{
boost::scoped_array<int> i(new int[2]);
*i.get() = 1;
i[1] = 2;
cout << "obj addr = " << i.get() << endl; //get() 返回所含对象的地址
cout << "i[0] = " << i[0] << endl; //operator[]() 访问数组中特定的元素
cout << "i[1] = " << i[1] << endl; //operator[]() 访问数组中特定的元素
i.reset(new int[3]);
cout << "new obj addr = " << i.get() << endl; //get() 返回所含对象的地址
system("pause");
return 0;
}