ASAN(Address Sanitizer)是一个用于检测内存错误的工具,可以检测到堆、栈和全局存储器中的缓冲区溢出、读取未初始化的内存和使用已释放的内存等问题,但它无法检测到新的内存泄漏,即在程序运行的过程中动态分配的内存没有被释放。
如果要检测新的内存泄漏,我们可以使用其他工具,比如Valgrind。但我们也可以手动编写代码来检测内存泄漏。下面是一个用于检测指针内存分配泄漏的示例代码:
//在头文件中声明以下两个函数
#ifdef __cplusplus
extern "C" {
#endif
//定义一个全局变量用于存储指针分配的地址
static void* mem_ptrs[1024] = { 0 };
static int mem_count = 0;
//记录指针分配的地址
void record_mem_allocation(void* ptr) {
if (mem_count < 1024)
mem_ptrs[mem_count++] = ptr;
}
//检查指针是否被释放
void check_for_memory_leaks() {
for (int i = 0; i < mem_count; i++) {
if (mem_ptrs[i])
fprintf(stderr, "Memory leak detected for address %p\n", mem_ptrs[i]);
}
}
#ifdef __cplusplus
}
#endif
//在代码中使用以下方式来记录和检查内存分配情况
#include
#include
int main() {
//分配内存并记录指针
void* ptr = malloc(1024);
record_mem_allocation(ptr);
//一些操作
//检查内存泄漏
check_for_memory_leaks