EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针

时间:2022-11-01 07:44:04

一般的智能指针都是通过一个普通指针来初始化,所以很容易写出以下的代码:

#include <iostream>

using
namespace std;

int
func1(){

//返回一个整数的函数

}

void
func2(AutoPtr<int*> ptr,int t){

//一些操作

}

int
main(){

func2(AutoPtr<int*>(new
int(5)),func1());

//其他操作

}

乍一看,这段代码好像没有什么问题,但实则暗藏隐患。

我们在调用func2的时候,里面的参数是需要运算的,运算一共有三步:

  1. int *t=new int(5);// 假设中间变量为t
  2. AutoPtr<int*> param(t);// 假设中间变量为param
  3. func1();

我们知道,1一定在2前面调用,但是3的调用顺序就不一定了.

我们假设一种情况:调用顺序为1->3->2

假设我们在调用3的时候,抛出了一个异常,这时候1已经调用完毕,也就是说,内存已经分配了,但是没有成功的放入智能指针中。这块内存不会被自动释放。于是引发了内存泄漏。

为了避免这个情况,我们可以将该过程分为两步:

#include <iostream>

using
namespace std;

int
func1(){

//返回一个整数的函数

}

void
func2(AutoPtr<int*> ptr,int t){

//一些操作

}

int
main(){

AutoPtr<int*>
param(new
int(5));

func2(param,func1());

//其他操作

}

只要确保智能指针的初始化不被打断,该隐患自然就会解除。

即使func1抛出异常,此时,智能指针已经初始化完毕,可以在析构函数中释放掉管理的内存。

EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针的更多相关文章

  1. 以独立的语句将new对象置入智能指针

    以独立的语句将newed对象置入智能指针: processWidget(std::tr1::share_ptr<Widget>(new Widget) , priority()); 我们在 ...

  2. Effective C&plus;&plus;&lpar;17&rpar; 以独立语句将newed对象置入智能指针

    问题聚焦:     使用了资源管理对象(如智能指针),就一定是安全的吗?显然不是.     资源泄露发生可能在于,在“资源被创建”和“资源被转换为资源管理对象”两个时间点之间有可能发生异常干扰. 看下 ...

  3. Effective C&plus;&plus; 条款17 以独立语句将newed对象置入智能指针

      对于函数: int priority(); void processWidget(std::tr1::  shared_ptr<Widget> pw,int priority); 调用 ...

  4. 条款17:以独立语句将newed对象置入智能指针(Store newed objects in smart pointers in standalone statements)

    NOTE: 1.以独立语句将newed对象存储于智能指针内.如果不这样做,一旦异常被抛出,有可能导致难以察觉的资源泄漏.

  5. &lbrack;Effective C&plus;&plus; --017&rsqb;以独立语句将newed对象置入智能指针

    这一节也比较简单,先假设我们有如下的函数: int foo(); void memFoo(shared_ptr<T> pw, int foo); 现在假设我们要调用memFoo函数: me ...

  6. 条款17:以独立语句将newed对象置入智能指针

    请牢记: 以独立语句将newed对象存储于(置入)智能指针内.如果不这样做,一旦异常被跑出来,有可能导致难以察觉的资源泄露. 假设有个函数用来处理程序的优先权,另一个函数用来在某动态分配所得的Widg ...

  7. Effective C&plus;&plus; -----条款17:以独立语句将newed对象置入智能指针

    以独立语句将newed对象存储于(置入)智能指针内.如果不这样做,一旦异常被抛出,有可能导致难以察觉的资源泄露.

  8. 《Effective C&plus;&plus;》——条款17:以独立语句将newed对象置入智能指针

    假设有如下两个函数: int priority(); void processWidget(std::tr1::shared_ptr<Widget>pw, int priority); 对 ...

  9. 【17】以独立语句将newed对象置入智能指针

    1.为什么? 考虑下面的情况:方法声明为void processWidget(shared_ptr<Widget> pw,int priority). 调用方法 processWidget ...

随机推荐

  1. 解析json串,利用正则表达式,split

    public class SplitJson { public static void main(String[] args) {        // TODO Auto-generated meth ...

  2. tmux&sol;screen里面如何用鼠标滚轮来卷动窗口内容

    tmux里面用鼠标滚轮来卷动窗口内容 在 tmux里面,因为每个窗口(tmux window)的历史内容已经被tmux接管了,所以原来console/terminal提供的Shift+PgUp/PgD ...

  3. HTML上传文件写法

    来源于:http://www.cnblogs.com/SkySoot/p/3525139.html html 表单上传文件 一般处理程序由于没有 apsx 页面的整个模型和控件的创建周期,而比较有效率 ...

  4. ubuntu 彻底删除软件包

    找到此软件名称,然后sudo apt-get purge ......(点点为为程序名称),purge参数为彻底删除文件,然后sudo apt-get autoremove,sudo apt-get ...

  5. 【Android - 基础】之PopupWindow的使用

    创建一个类继承自PopupWindow,编写自定义的PopupWindow类.示例代码如下: import android.app.Activity; import android.graphics. ...

  6. C&num;动态二维数组输出

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  7. javacript 面向对象

    1.对象 使用Object创建对象 var p = new Object(); p.name = 'jason'; p.sayName = function(){ alert(this.name); ...

  8. veridata实验例(5)在更改主键列值,update操作将被分成两个语句

    veridata实验例(5)更改主键列值,update操作将被分成两个语句 续接"veridata实验举例(4)验证veridata查找出updata.delete操作导致的不同步现象&qu ...

  9. STM32应用笔记转载

    stm32 外部中断嵌套[操作寄存器+库函数] stm32 NVIC中断管理实现[直接操作寄存器] stm32 SPI通信[操作寄存器+库函数] stm32 i2c通信 [操作寄存器+库函数] stm ...

  10. &lbrack;Angular Tutorial&rsqb; 4 - Directory and File Organization

    在这一步中,我们将不会在我们的应用中添加任何新功能,相反,我们打算退回一步,重构我们的代码库,移动我们的代码和文件,以此来使我们的应用更具易扩展性和可维护性. 在先前的步骤中,我们已经见识到了如何将我 ...