malloc和new的区别 begin http://blog.csdn.net/miss_acha/article/details/7279915#comments 2.三种形式的new表达式  

1.综述

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

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

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

4,C++程序经常要调用C函数,而C程序只能用malloc/free管理动态内存

new 是个操作符,和什么"+","-","="……有一样的地位。

malloc是个分配内存的函数,供你调用的。

new是保留字,不需要头文件支持。

malloc需要头文件库函数支持。

new 建立的是一个对象,

malloc分配的是一块内存。

new建立的对象你可以把它当成一个普通的对象,用成员函数访问,不要直接访问它的地址空间

malloc分配的是一块内存区域,就用指针访问好了,而且还可以在里面移动指针。

简而言之:

new 是一个操作符,可以重载

malloc是一个函数

new 初始化对象,调用对象的构造函数,对应的delete调用相应的析构函数

malloc仅仅分配内存,free仅仅回收内存

2.三种形式的new表达式

<1>单个对象的动态分配

int *pi = new int(11); // initializer

int *q = new int;   //assign

*q = i;

<2>数组的动态分配

int *pi = new int[11];   // 分配有11个元素的动态数组

int (*pia)[11] = new int [22][11];   //分配一个含有 22 * 11 个元素的二维数组

  • 动态分配的数组不能给出初始化值,一般在 for 循环中一个一个的初始化

for(int i = 0; i < 11; i++)

      pi[i] = 0;

  • 动态数组的第一维不必是常量值, 这样就不必在编译时刻就知道维数,我们可以根据需要分配大小合适的内存单元
  • 释放动态数组:        delete [ ] pi;    如果不小心忘记了空括号,编译器不会捕捉到这个错误, 务必要小心
  • 一般为了避免动态分配数组带来的内存管理的问题, 我们使用c++ 的 标准库vector, list or string 会自动管理内存的容器类型

---------------------

常量对象的动态分配

const int *pic = new const int(1024);

  • const 对象必须被初始化, 否则会编译错误,(因此我们也不能创建const数组,因为const数组不能被初始化,除了类数组)
  • 用new表达式返回的值作为初始值的指针必须是一个指向const类型的指针. eg: const int
  • 它的生命期同样也用delete表达式来结束 eg: delete pic;

<3>定位new表达式(placement new expression)

形式: new (place_address) type-specifier

头文件: #include <new>

place_adress必须是指针

eg:

int *buf = new int[2];

int *pb = new (buf) int;

*pb = 11;

cout << *pb << endl;             // 11

cout << *buf << endl;            // 11

cout << pb << endl;                 // 同样pb跟buf的所指向的地址也是相同的

cout << buf << endl;                //

int *pp = new (buf + 1) int;

*pp = 22;

  • 因为定位符并不分配内存,所以我们并没有与定位符相匹配的delete表达式, 对此我们需要删除的是分配内存的指针,在上面的例子中我们 delete [] buf;new和delete运算符用于动态分配和撤销内存的运算符.