用placement new 构造对象的话 可以显式的去析构。也可以不调用析构,但是要手动的释放operator new的内存。 在STL的源码中, vector分配在构造内存池中 就是采用的这种内存 申请方法。
#include <malloc.h>
#include <new>
class A
{
public:
A()
{
printf("class A conduct\n");
}
~A()
{
printf("class A delete");
}
};
int main(int argc, char* argv[])
{
void * p = malloc(20);
int * a =new (p) int;
*a = 12;
printf("%d\n", *(int *)p);
p = realloc(p, sizeof(A));
A* test = new (p) A;
test->~A();
delete p;
return 0;
}
用placement new 构造对象的话 可以显式的去析构。也可以不调用析构,但是要手动的释放operator new的内存。 在STL的源码中, vector分配在构造内存池中 就是采用的这种内存 申请方法。
#include <malloc.h> #include <new> class A { public: A() { printf("class A conduct\n"); } ~A() { printf("class A delete"); } }; int main(int argc, char* argv[]) { void * p = malloc(20); int * a =new (p) int; *a = 12; printf("%d\n", *(int *)p); p = realloc(p, sizeof(A)); A* test = new (p) A; test->~A(); delete p; return 0; }