C++中new的用法有三种(两大类),其一是new operator(new表达式),其二是operator new(new操作符)。
new表达式比较常见,也最常用,例如:
string* pStr = new string("ABC");//上面这个new表达式完成了两件事情:申请内存和初始化对象
new操作符类似于C语言中的malloc,它只是负责申请内存,但不负责内存块的初始化。
例如:
void* pBuffer = operator new(sizeof(string)); //注意这里面的operator关键字
这是new的第二种用法。
new的第三种用法就不很常见,官方的说法是placement new,它用于在给定的内存中初始化对象,也就是说你手中已有一块闲置的内存(如用new的第二种用法申请的内存),现在需要将其初始化。
例如:
void* pBuffer = operator new(sizeof(string));//那么现在pBuffer是你所拥有闲置内存的指针 pBuffer = new(pBuffer) string("ABC"); //调用了placement new,在pBuffer所指向的内存中初始化string类型的对象,初始值是"ABC"
事实上,placement new也是new表达式的一种,但是比普通的new表达式多了一个参数,当然完成的操作和返回值也不同。
因此上面new的第一种用法可以分解两个动作,分别为后面的两种用法。
与new对应的delete没有三种语法,它只有两种,分别是delete operator和operator delete,也称为delete表达式和delete操作符。delete表达式和new表达式对应,完成对象的析构和内存的释放操作。而delete 操作符只是用于内存的释放,和C语言中的free相似。
例如:
string* pStr = new string("ABC"); ... delete ps; //调用delete表达式,先析构再释放 void* pBuffer= operator new(sizeof(string)); ... operator delete(pBuffer); //释放
而placement new对象的释放步骤为:
void *pVec = operator new(sizeof(vector<int>)); pVec = new(pVec) vector<int>(8, 0); ... static_cast<vector<int>* >(pVec)->~vector(); //调用析构函数 operator delete(pVec); // 释放内存 pVec = NULL;
关于placement new,以后有时间再细谈。