我正在编写全局 delete/new 运算符的调试版本来检测内存泄漏、双重删除和未分配内存上的删除。
就"new"运算符而言,我覆盖了全局新运算符并使用宏传递了文件名和行号信息。覆盖的“new”运算符将内存地址、文件名、大小和行号信息存储在以地址为键的映射中。
我也覆盖了“删除”运算符,它从 map 中删除了已删除地址的条目。现在我想将删除的内存信息存储在另一个映射中,该映射存储调用“删除”的位置的文件名和行号信息。
但是删除运算符只接受参数(要删除的对象的内存地址)。 有人能告诉我如何检测代码中的双重删除吗?
最佳答案
您已经在重载的 new
中创建了分配的内存地址(键)和文件名、行号(值字段)的映射。
在重载删除时,只需检查所传递的地址是否存在于您创建的 map 中。
如果是,您认为对 delete
的调用是有效的,并从您的 map 中删除该地址条目。
如果否,则将 delete 调用视为错误,delete 在未通过您的 new 分配的指针上调用
或尝试多次调用 delete
。
关于c++ - 如何检测 C++ 中未分配内存的双重删除或删除?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6327107/