#include "boost/scoped_ptr.hpp"

#include <iostream>

#include <memory>//contain auto_ptr 

using namespace std;

using  boost::scoped_ptr;

int main(int argc, char* argv[])

{

scoped_ptr<int > sp( new int(10) ) , sp2;

 //sp = new int(10)

 //error,由于拷贝构造函数和赋值构造函数都是私有的

 //

 cout<< *sp<<endl;

//sp2=sp;  //error

 int *p=sp.get(); //不会导致sp失去空间的占有权

 //delete p ;//将导致错误,由于sp是分配的空间的全部者,仅仅有它才有权利进行释放

 *p = 20;

 cout<< *sp<<endl;

 

 auto_ptr<int> ap(new int(1)) ,ap2;

 //ap = new int(1); //error

 ap2 = ap ; //ap将失去分配的空间的全部权

 int *p2 = ap2.get();//不会导致ap2失去空间的占有权

 *p2=100;

 //delete p2 ;//将导致错误,由于ap2是分配的空间的全部者,仅仅有它才有权利进行释放

 return 0;

}



/////////////////////////////////////////////////////

智能指针类事实上包括有几个数据成员当中一个就是全部权标记,另外一个就是指向动态分配的空间的地址。

1.仅仅有对这个动态分配的空间拥有全部权的指针或者智能指针对象才有权利去释放这个空间。

由于假设使用指针的话没有全部权保护,所以尽管原则上是拥有全部权的才干释放可是假设是使用指针 就没办法确定一个指针是否占有全部权。所以不建议这么做。

//全部权与使用权分离。有使用权不一定有全部权!

另外智能指针类能够通过构造函数的訪问属性和參数特性来禁止某些操作或同意某些操作。

比方把重载赋值为私有来禁止赋值,把拷贝构造函数设置为私有来禁止拷贝。

2.对于智能指针而言get操作智能取得动态分配的空间的地址。而不能使智能指针失去全部权。

3.一个动态分配的空间在仅仅有一个全部权而且在某一个仅仅能有一个全部者。

但能够有多个使用者。

使用者能够对空间的内容进行赋值,但不同意进行释放操作。

auto_ptr代表的动态分配的空间的全部权是能够转移( 通过赋值)的。

scoped_ptr代表的动态分配的空间的全部权则不能转移(重载赋值为私有来禁止赋值,把拷贝构造函数设置为私有来禁止拷贝。)!

auto_ptr and scoped_ptr的更多相关文章

  1. 智能指针之auto_ptr和scoped_ptr

    部分参考地址https://blog.csdn.net/yanglingwell/article/details/56011576 auto_ptr是c++标准库里的智能指针,但是具有以下几个明显的缺 ...

  2. 智能指针 auto_ptr、scoped_ptr、shared_ptr、weak_ptr

    什么是RAII? RAII是Resource Acquisition Is Initialization的简称,是C++语言的一种管理资源.避免泄漏的惯用法. RAII又叫做资源分配即初始化,即:定义 ...

  3. boost准模板库scoped_ptr指针的使用以及auto_ptr智能指针的对照

    首先我们看看scoped_ptr的基本使用,包括了swap(),get(),reset()的使用,重要的提醒是作用域结束的时候会自己主动析构,无需手动的释放资源: #include<boost/ ...

  4. Boost scoped_ptr scoped_array 以及scoped_ptr与std::auto_ptr对比

    boost::scoped_ptr和std::auto_ptr非常类似,是一个简单的智能指针,它能够保证在离开作用域后对象被自动释放.下列代码演示了该指针的基本应用: #include <str ...

  5. Resource Acquisition Is Initialization(RAII Idiom)

    原文链接:http://en.wikibooks.org/wiki/More_C%2B%2B_Idioms/Resource_Acquisition_Is_Initialization Intent ...

  6. boost-智能指针

    使用boost的智能指针需要包含头文件"boost/smart_ptr.hpp",c++11中需要包含头文件<memory> 1.auto_ptr.scoped_ptr ...

  7. boost之内存管理

    内存管理一直是令C++程序员最头疼的工作,C++继承了C那高效而又灵活的指针,使用起来稍微不小心就会导致内存泄露.野指针.越界访问等访问.虽然C++标准提供了只能指针std::auto_ptr,但是并 ...

  8. 你说你会C++? —— 智能指针

    智能指针的设计初衷是:      C++中没有提供自己主动回收内存的机制,每次new对象之后都须要手动delete.稍不注意就memory leak. 智能指针能够解决上面遇到的问题. C++中常见的 ...

  9. 智能指针剖析(上)std::auto_ptr与boost::scoped_ptr

    1. 引入 C++语言中的动态内存分配没有自动回收机制,动态开辟的空间需要用户自己来维护,在出函数作用域或者程序正常退出前必须释放掉. 即程序员每次 new 出来的内存都要手动 delete,否则会造 ...

随机推荐

  1. springMVC框架搭建

    springMVC和struts一样为MVC框架,但是springMVC与spring做到无缝连接. 在搭建SpringMVC时可以在官网上下载最新的jar包. http://www.springso ...

  2. entity framework 6 我写了一个公用数据类

    public class BaseDAL { string strConn = ""; public BaseDAL(string connString) { strConn = ...

  3. EasyUI - Tabs

    代码: 判断是不是已经存在,如果存在,则直接选中,否则创建新的tab. $('#tabs').tabs({ fit: true, border: false }) $('#Tree').tree({ ...

  4. 创建采购订单批到程序用的BAPI

    CALL FUNCTION 'BAPI_PO_CREATE1' EXPORTING poheader = poheader poheaderx = poheaderx * POADDRVENDOR = ...

  5. abap四舍五入的函数

    VALUE '1.6'. DATA p2 TYPE i . CALL FUNCTION 'ROUND' EXPORTING DECIMALS = input = p1 SIGN = '+ ' IMPO ...

  6. PP屏幕增强点

    生产订单CO01/CO02/CO03屏幕增强 smod:PPCO0012 工票输入CO11N SMOD:CONFPP07 增强里经常会用内存读取数据:比如: ) TYPE c. FIELD-SYMBO ...

  7. Servlet的学习之Session(3)

    在上一篇<Servlet的学习之Session(2)>我们知道了Session能实现一个会话过程中保存数据或者多个会话中实现同一个Session的关键因素就是Cookie,只是Cookie ...

  8. ice cave

    Description You play a computer game. Your character stands on some level of a multilevel ice cave. ...

  9. Python Unittest 自动化单元测试框架Demo

    python 测试框架(本文只涉及 PyUnit) https://wiki.python.org/moin/PythonTestingToolsTaxonomy 环境准备 首先确定已经安装有Pyth ...

  10. Servlet过滤器——创建过滤器

    1.概述 介绍如何创建一个过滤器,并使用过滤器在打开页面的同时输出信息,此功能是由过滤器处理完成的. 2.技术要点 Serlvet过滤器实现了Filter接口,在Filter接口中定义了以下几个方法: ...