c++ - 如何检测 C++ 中未分配内存的双重删除或删除?

标签 c++ memory memory-leaks new-operator delete-operator

我正在编写全局 delete/new 运算符的调试版本来检测内存泄漏、双重删除和未分配内存上的删除。

就"new"运算符而言,我覆盖了全局新运算符并使用宏传递了文件名和行号信息。覆盖的“new”运算符将内存地址、文件名、大小和行号信息存储在以地址为键的映射中。

我也覆盖了“删除”运算符,它从 map 中删除了已删除地址的条目。现在我想将删除的内存信息存储在另一个映射中,该映射存储调用“删除”的位置的文件名和行号信息。

但是删除运算符只接受参数(要删除的对象的内存地址)。 有人能告诉我如何检测代码中的双重删除吗?

最佳答案

您已经在重载的 new 中创建了分配的内存地址(键)和文件名、行号(值字段)的映射。

在重载删除时,只需检查所传递的地址是否存在于您创建的 map 中。

如果是,您认为对 delete 的调用是有效的,并从您的 map 中删除该地址条目。

如果否,则将 delete 调用视为错误,delete 在未通过您的 new 分配的指针上调用尝试多次调用 delete

关于c++ - 如何检测 C++ 中未分配内存的双重删除或删除?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6327107/

相关文章:

c - 包含函数指针数组的结构需要多少内存?

java - Pod OOM - Xmx 未被尊重

memory - 应该给 Tcl dict 什么值以获得最小内存?

c++ - 数组的资源泄漏

c++ - 在 2018 年的 C++11 及更高版本中,helper init() 函数是否被视为错误形式?

c++ - 子类递归方法调用

java - 使用 7mb RAM 的 Android FinalizerReference

c - 将文件读取到双向链表时泄漏内存

c++ - 将字符串文字分配给 char*

c++ - 当没有抛出任何东西时,带有 try-catch 的代码是否仍然很慢