我正在编写全局删除/新运算符的调试版本,以检测内存泄漏,重复删除和删除未分配的内存。
就"new"运算符而言,我覆盖了全局新运算符,并使用宏传递了文件名和行号信息。覆盖的"new"运算符将内存地址,文件名,大小和行号信息存储在键入地址的映射中。
我也覆盖了“删除”运算符,该运算符从 map 中删除了已删除的地址条目。现在,我想将删除的内存信息存储在另一个映射中,该映射存储从中调用“删除”的文件名和行号信息。
但是delete运算符仅采用参数(要删除的对象的内存地址)。
有人可以告诉我如何检测代码中的双重删除吗?
最佳答案
您已经在重载的new
中创建了分配的内存地址(键)和文件名,行号(值字段)的映射。
在您的重载删除中,只需检查所传递的地址在您创建的 map 中是否存在。
如果是,则您认为对delete
的调用是有效的,然后从 map 中删除该地址条目。
如果否,则将删除调用视为delete called on a pointer not allocated through your new
或trying to call delete multiple times
错误。