博客园  :: 首页  :: 联系 :: 订阅 订阅  :: 管理

new/delete&malloc/free

Posted on 2009-09-27 13:43  RUI2021  阅读(242)  评论(0编辑  收藏  举报
 归结点:

    1、malloc与free是C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。

  2、对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。

  3、因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以一个能完成清理与释放内存工作的运算符delete。

  4、new 是个操作符,和什么”+”,”-”,”=”…有一样的地位.
  5、new是保留字,不需要头文件支持.malloc需要头文件库函数支持. 
      6、new/delete是可以重载的,而重载之后,就成为了函数当new/delete在类中被重载的时候,可以自定义申请过程,比如记录所申请内存的总长度,以及跟踪每个对象的指针。
  7、new 建立的是一个对象,malloc分配的是一块内存. new建立的对象你可以把它当成一个普通的对象,用成员函数访问,不要直接访问它的地址空间。   

  8、malloc分配的是一块内存区域,就用指针访问好了,而且还可以在里面移动指针
     9、new/delete,其实内部也调用了malloc/free
     10、malloc在申请内存的时候,必须要提供申请的长度,而且返回的指针是void*型,必须要强转成需要的类型。free和delete可以释放NULL指针。
     11、都必须配对使用。
     12、对类类型,delete一个数组时(比如,delete []sa;),要为每一个数组元素调用析构函数。但对于delete表达式(比如,这里的delete []sa),它并不知道数组的元素个数(只有new函数和delete函数知道)。因此,必须有一种手段来告诉delete表达式的数组大小是多少。
     13、 使用new动态分配内存:若没有足够内存,则new返回0(空值指针null pointer)
     14、不要使用delete释放不是new分配的内存,delete释放指针指向的内存,但不会删除指针本身
     15、创建数组时的静态联编与动态联编:数组声名int a[10], 静态联编,数组的长度在编译时确定; 用new[]创建数组,动态联编,运行时为数组分配内存空间。动态-运行时分配内存。


举几个简单的例子吧:
int* pn = (int*)malloc(sizeof(int));
*pn = 15;
free(pn);
pn = NULL; // 置空
free(pn); // OK,没有问题
double* pd = new double;
*pd = 212.211;
delete = pd;
short* ps = new short[128]; // new出一个数组来
ps[1] = 1231;
ps[11] = 1111;
delete[] ps;  // 请注意delete的语法。

// 以下是一个重载new操作符的例子,一般来说是不会用到的,除非要设计一个编译器之类的东西。
class Sample
{
public:
    static CSample* operator= new()
    {
        CSample* p = (CSample*)malloc(size(Sample));
        return p;
    }
}