new的3种形态: new operator , operator new , placement new
new operator:
new操作符,像 + - * / && . :: ?: 等操作符一样,是语言内置的, 它不能被重载,不能改变其行为。
它的行为包括分配内存的 operator new 和调用构造函数的 placement new。
new operator 实际上做了三件事:获得一块内存空间、调用构造函数、返回正确的指针。如果创建的是简单类型(如char)的变量,那么第二步会被省略。
比如:
CTest* pT = new CTest(1, 2);
它的调用实际上等效于:
void* p = operator new( sizeof(CTest) );
CTest* pT = new(p) CTest(2, 2);
其中前一句是operator new分配内存,后一句是placement new调用构造函数,并返回正确的CTest*指针。
operator new:
操作符new,原型为:
void* operator new(size_t size);
它分配指定大小的内存, 可以被重载, 可以添加额外的参数, 但第一个参数必须为 size_t 。
它除了被 new operator 调用外也可以直接被调用, 如:
void* p = operator new(sizeof(CTest));
这种用法和调用 malloc 一样, 只分配了sizeof(CTest)大小的内存。
placement new:
置换new,它在一块指定的内存上调用构造函数, 包含头文件<new>之后也可以直接使用,如:
CTest* pT = new(p) CTest(2, 2);
它在p这块内存上调用CTest的构造函数来初始化CTest。
如果用 placement new 构造出来的对象,必须显示的调用对象的析构函数,如:
pT->~CTest();
然后释放内存, 调用 operator delete (对应于分配时的 operator new)
operator delete(pT);