3

GCC 和 Clang 编译器都支持LeakSanitizer,这有助于发现 C 程序中的内存泄漏。有时内存泄漏是不可避免的(例如,因为它正在测试套件中进行测试)。

这样的内存可以使用Leak Sanitizer 接口进行注释:

#include <sanitizer/lsan_interface.h>

void *p = create_new_object();
__lsan_ignore_object(p);

然而,这将在不支持 LSan 的编译器上中断。在 Address Sanitizer 中,此构造可用于检测 ASAN 的可用性:

/* __has_feature(address_sanitizer) is used later for Clang, this is for
 * compatibility with other compilers (such as GCC and MSVC) */
#ifndef __has_feature
#   define __has_feature(x) 0
#endif

#if __has_feature(address_sanitizer) || defined(__SANITIZE_ADDRESS__)
    /* ASAN-aware code here. */
#endif

在 Clang中没有__has_feature(leak_sanitizer)检测到 LSan 的__SANITIZE_LEAKS__存在,对于 GCC 也不存在。无论如何,我如何检测 ASAN 可用性?请注意,LSan 可以独立于 AddressSanitizer 和 ThreadSanitizer 启用。

4

1 回答 1

3

由于编译器没有为自己设置预处理器定义,因此必须为自己做这件事。

一种-fsanitize=leak -DMYLEAKSAN=1使用 LeakSanitizer 编译或没有 LeakSanitizer 一种编译使用-DMYLEAKSAN=0. 如果确实忘记定义MYLEAKSAN编译器将停止。

#ifndef MYLEAKSAN
#   error: MYLEAKSAN must be either 0 or 1
#endif
#include <stdio.h>
#include <stdlib.h>
#if MYLEAKSAN
#   include <sanitizer/lsan_interface.h>
#endif

int main(void)
{
    void *p = malloc(5);
#if MYLEAKSAN
    __lsan_ignore_object(p);
#endif
}
于 2015-07-08T15:02:29.500 回答