假设class A
有一些动态分配的数据数组,class A
有一个用户定义的析构函数来释放由A
分配的内存( RAII 样式)。
然后,如果我们创建一个class A
的动态数组,我们可以将其称为数组B
,并使用标准的free
函数来free
B
所声明的A
资源},我们能否确保B
中的每个动态数组都已正确发布?
当A
和'A'
存在嵌套类型关系时,情况又如何呢? 'B'
被释放后,{{1}} s的所有资源是否都能正常处理?
答案 0 :(得分:2)
这完全取决于你是如何做到的。这是使用free
的完全合理的方式:
char * addr = static_cast<char *>(std::malloc(sizeof(A) * 2));
A * p = new (addr) A(100);
A * q = new (addr + sizeof(A)) A(50);
q->~A();
p->~A();
std::free(addr); // fine
如果A
的构造函数中没有例外,这不会泄漏内存。与往常一样,您必须在free
/ malloc
/ calloc
获得的指针上精确调用realloc
。
这种编写代码的方法是疯了吗?当然。不要这样做。请改用std::vector<A>
。