使用free()释放new分配的内存空间
Releasing memory space allocated by new using free()
据我所知,delete[]
用于释放new
分配的内存空间。CCD_ 3也可以用于释放该存储器空间。那么,当使用free()
代替delete[]
释放内存时,我将不得不面对哪种类型的问题?
"
free()
也可以用来释放内存空间。">
否,free()
不能用于释放分配有new()
或new[]
的内存。
"那么,当使用
free()
代替delete[]
释放内存时,我将不得不面对哪种类型的问题?">
为分配有new[]
的内存使用free()
而不是delete[]
是未定义的行为(此外,不会调用复杂对象的析构函数),这可能会导致运行时异常。
来自POSIX兼容参考(强调矿):
free()
函数将导致ptr指向的空间被释放;即可用于进一步分配。如果ptr是空指针,则不会发生任何操作。否则,如果参数与calloc()
、malloc()
、posix_memalign()
、realloc()
或strdup()
函数先前返回的指针不匹配,或者如果对free()或realloc()
的调用释放了空间,则行为未定义任何引用释放空间的指针的使用都会导致未定义的行为
好吧,new[]
或new()
的一些实现可能依赖于malloc()
函数族,而其他实现可能不依赖。因此,您不能确定已分配的内存指针可以安全地与free一起使用(即使您不关心析构函数调用问题)。
结论:
delete[]
的使用仅被很好地定义为对使用new[]
分配的存储器进行操作,delete
对应于new
的结果。
同样,free()
的使用仅结合使用free()
0函数族分配的内存进行了很好的定义。
关于应用于您(原始)问题的c标记,由于c不支持delete
或new
,因此为c语言询问这一点是非常无用的
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?