码迷,mamicode.com
首页 > 编程语言 > 详细

STL--C++中 destory() 和deallocate()以及delete函数的相关性和区别性,destorydeallocate

时间:2016-07-09 16:31:10      阅读:257      评论:0      收藏:0      [点我收藏+]

标签:

  • 这里非常的绕口  需要仔细的来看看:

     destory(): 显示调用一个对象的析构函数 相当于释放一个对象需要释放的一些动态内存 为下次真正释放对象做准备

     deallocate():真正的释放一个内存块。这是一个上层封装也就是delete函数的上层封装 在STL的空间配置器中 有可能会调用delete还给OS 也有可能就是放在内存池中 但是对于用户来讲就是释放内存块。

     看一个例子 应该就明白了真正的含义了:

  • 技术分享
     1 #include <iostream>
     2 
     3 #include <stdlib.h>
     4 
     5 #include <unistd.h>
     6 
     7 using namespace std;
     8 
     9 class A
    10 
    11 {
    12 
    13 public:
    14 
    15     A()
    16 
    17     {
    18 
    19         data=new char[1000000];
    20 
    21     }
    22 
    23     ~A()
    24 
    25     {
    26 
    27         //free the data memory
    28 
    29         delete []data;
    30 
    31     }
    32 
    33 private:
    34 
    35     char *data;
    36 
    37 };
    38 
    39 int main(int argc,char* argv[])
    40 
    41 {
    42 
    43     for(;;)
    44 
    45     {
    46 
    47         A *a=new A;
    48 
    49         std::allocator<A> allocat;
    50 
    51         allocat.deallocate(a,sizeof(A));
    52 
    53  
    54 
    55     }
    56 
    57     return 0;
    58 
    59 }
    View Code

    明显 这样的做法会出问题,运行到一定的时间内会抛出异常。所以deallocate只是释放对象内存,并没有调用对象的构造函数释放对象内的动态内存  这点要注意  如果调用了一个  allocat.destory(a); 程序就不会有bug了 

    所以在C++中, 对象释放和对象内动态内存释放是需要注意的 弄不好 就会出现内存泄露现象。

    这里的delete操作符号本身带有2个动作:调用析构函数 2释放内存。而::operator delete就只有释放内存。 deallocate函数就是基于operator delete函数封装的。 这点需要记住

    可以通过看STL源码发现 :像vector()的析构函数都是有2个操作: destory() 释放对象内的动态内存(如果有) deallocate是释放对象本身占有的内存  通过这2点  就能保证内存不能泄露了

STL--C++中 destory() 和deallocate()以及delete函数的相关性和区别性,destorydeallocate

标签:

原文地址:http://www.cnblogs.com/Kobe10/p/5656015.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!