zoukankan      html  css  js  c++  java
  • EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针

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

    #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抛出异常,此时,智能指针已经初始化完毕,可以在析构函数中释放掉管理的内存。

  • 相关阅读:
    转载c++中的多态性
    sdk环境下数据库访问之ADO
    ADO数据库访问问题
    PopMenu 弹出式菜单(变灰,禁用,激活)
    控制台窗口界面控制设计
    判断整数序列是不是二元查找树的后序遍历结果
    把二元查找树转变成排序的双向链表
    二叉树平衡因子应用举例
    二元查找树转换为它的镜像
    满二叉树先序、中序和后序之间的转换
  • 原文地址:https://www.cnblogs.com/SkyFireITDIY/p/6224147.html
Copyright © 2011-2022 走看看