boost库学习之 scoped_ptr scoped_array

boost.smart_ptr库提供了六种智能指针:scoped_ptr、scoped_array、shared_ptr、shared_array、week_ptr和intrusive_ptr。

说到智能指针,我们会想到c++98标准中的自动指针auto_ptr.

auto_ptr获取指针所有权后,离开作用域时自动释放该指针指向的堆内存。也可以转移指针的所有权。
auto_ptr<A> ap_a1(new A);
auto_ptr<A> ap_a2(ap_a1); //发生所有权转移,此时ap_a1不再管理申请的A对象

if (ap_a1.get() == nullptr)
	cout << "ap_a1.get() == nullptr" << endl; //输出ap_a1.get() == nullptr

if (ap_a2.get() == nullptr)
	cout << "ap_a2.get() == nullptr" << endl;

scoped_ptr是一个很类似auto_ptr的智能指针。但scoped_ptr的所有权不能转让。

scoped_ptr把拷贝构造函数和赋值操作符声明为私有,重载了*和->操作符,因此可以把scoped_ptr当作指针一样使用。

需要包含<boost/scoped_ptr.hpp>头文件,引用boost命名空间

void func()
{
	scoped_ptr<A> sp_a1(new A);
	sp_a1->print();		    //支持普通指针的*、->操作符
	sp_a1.get()->print();       //成员函数get返回持有的指针
	sp_a1.reset(new A);         //reset不再持有之前的指针,删除指针,并持有新指针,会调用A类的析构函数
	sp_a1++;		    //错误,未定义递增操作符
	scoped_ptr<A> sp_a2(sp_a1); //错误,不支持指针所有权转移
}

不需要delete操作,scoped_ptr会自动帮我们释放资源,所以如果在之前对指针delete,scoped_ptr析构时再对指针delete可能会发生未定义行为。

scoped_ptr不会向auto_ptr一样转移指针所有权,会减少错误的发生,没有多余的操作,保证了与原始指针同样的效率,代码也更清晰。

scoped_array

scoped_array类似scoped_ptr,接口和功能几乎是与scoped_ptr相同,弥补了标准库中没有指向数组的智能指针的缺憾。

速度与原始数组几乎一样快,但不支持动态增长数组。不支持迭代器,不能搭配STL算法。

注意:

1.scoped_array接受的指针必须是new[]的结果,不能是new表达式的结果

2.scoped_array没有重载*、 ->操作符

3.重载了[]操作符,可以向普通数组用下标访问。

scoped_array<int> sa(new int[100]);  //包装动态数组
sa[0] = 10;                          //正确,重载了[]
*(sa + 1) = 20;                      //错误, 没有重载*

{
    scoped_array<int> sa(new int[100]);
}                                     //退出作用域自动释放数组资源
时间: 2024-12-28 15:47:18

boost库学习之 scoped_ptr scoped_array的相关文章

c++ boost库学习三:实用工具

noncopyable 大家都知道定义一个空类的时候,它实际包含了构造函数,拷贝构造函数,赋值操作符和析构函数等. 这样就很容易产生一个问题,就是当用户调用A a(“^_^") 或者A c="^_^" 时会发生一些意想不到的行为,所以很多时候我们需要禁用这样的用法. 一种方法就是把拷贝构造函数和赋值操作符显式的定义为private,但是这样需要很多代码. 于是boost库为大家提供了一个简单的方法:只需要将类继承于noncopyable就可以了. #include "

c++ boost库学习一:时间和日期

timer类 #include <boost\timer.hpp> #include "iostream" using namespace std; int _tmain(int argc, _TCHAR* argv[]) { boost::timer t; cout<<"max time span: "<<t.elapsed_max()/3600<<"h"<<endl; //596.5

boost库学习之regex

一.背景 项目中许多地方需要对字符串进行匹配,比如根据指定的过滤字符串来过滤文件名.刚开始是排斥使用boost库的,第一,我不熟悉boost库:第二,如果引入第三方库,就会增加库的依赖,这样的后果是,要么打包程序时,打包动态库,要么直接使用静态库编译,会使增大程序的大小. 刚开始是尝试自己写模糊匹配算法,很简单,就只支持_和%,这两个通配符,然后发现Linux下有一个fnmatch的函数,就是进行模糊匹配的,它支持shell通配符. 但是到最后发现,当需要区别很相似的字符串时,模糊匹配就不行了,

Boost库学习之旅入门篇

学习及使用Boost库已经有一段时间了,Boost为我的日常开发中带来了极大的方便,也使得我越来越依赖于boost库了.但boost功能太多,每次使用还是得翻看以前的 资料,所以为了以后可以更方便的使用,在此对常用的功能作一个总结,也希望以此与大家共勉. boost库下载,Svn地址: http://svn.boost.org/svn/boost/trunk 编译源码 编译boost库自带脚本解释工具: 使用vs自带命令行工具Visual Studio 命令提示(2010),运行bat脚本boo

boost库学习之开篇

本系列文章使用boost_1.58.0版本. 一.欢迎使用boost C++库 boost致力于提供一个免费的.便携的源代码级的库. 我们重视那些与C++标准一起工作良好的库.boost库将要成为一个应用广泛的库,成为应用程序可以依赖的平台.boost证书估计商业和非商业机构使用它. 我们的目标是建立已存在的练习而且提供对于库具体实现的引用以至于boost库适合于最后的标准.十个boost库已经包含在C++标准委员会的TR1而且将要被包含在即将到来的C++标准版本中.更多的boost库将目标放在

boost库学习之 date_time库

 date_time库是一个全面灵活的日期时间库,提供时间相关的各种所需功能,也是一个比较复杂的库.它支持从1400-01-01到9999-12-31之间的日期计算.使用时包含#include <boost/date_time/gregorian/gregorian.hpp>头文件, 引用boost::gregorian;命名空间. 日期 date是date_time库中的核心类.以天为单位表示时间点. date d1; //无效日期 date d2(2015, 1, 4); date d

boost库学习之 pool库

简单来说内存池预先分配了一块大的内存空间,然后在其中使用某种算法高效快速的自定制内存分配. pool库包含四个组成部分,最简单的pool,分配类实例的object pool,单件内存池singleton_tool和用于标准库的pool_alloc. 为了使用pool组件,需要包含<boost/pool/pool.hpp>头文件. 操作函数: pool的构造函数接受一个size_type类型的整数request_size,指示每次pool分配内存块的大小 成员函数get_request_size

boost库学习之 shared_ptr

shared_ptr与scoped_ptr都包装在堆上分配的动态对象,都重载了*和->操作符以模仿原始指针行为,但shared_ptr实现的是引用计数型的智能指针,当没有代码使用时计数为0,此时释放被包装的动态分配的内存. shared_ptr可以被自由地拷贝和赋值.shared_ptr可以安全地放到标准容器中. 引用<boost程序库完全开发指南>中的话:"shared_ptr非常有价值.非常重要.非常有用." shared_ptr有多种形式的构造函数,应用于各种可

boost库学习之 timer库

timer是一个很小的库,提供简易的时间度量和进度显示,包括timer.progress_timer.progress_display三个类.不适合高精度的时间测量任务,精度依赖于操作系统或编译器,可提供的最大时间跨度只有几百个小时,不适合大跨度的时间段测量. timer类 先来看一下标准库如何计时: #include <iostream> #include <ctime> using namespace std; int main() { clock_t begin, end;