SanitizerAddress处理内存问题

Sanitizer是GCC提供的一种内存检查工具,可用于检测内存泄漏、越界和线程竞态等错误。通过添加编译选项如-fsanitize=address、-fsanitize=memory等,可以启用不同类型的检查。为了在发生错误时保持程序运行,可以使用-fno-omit-frame-pointer,并通过ASAN_OPTIONS环境变量配置错误处理行为,如halt_on_error=0来避免立即退出。此外,还可以设置detect_leaks=1来检测内存泄漏。
摘要由CSDN通过智能技术生成

关于内存泄漏、内存越界,有个gcc默认的工具Sanitize工具

编译时使用选项

地址错误: -fsanitize=address
内存错误: -fsanitize=memory
内存泄漏: -fsanitize=leak
线程竞速问题: -fsanitize=thread
未定义问题: -fsanitize=undefined
为方便回溯可同时添加保留函数指针标志:-fno-omit-frame-pointer
 

一般在CFLAGS 中添加 上述选项,特别是address选项。

# -fsanitize-recover=address:一般后台程序为保证稳定性,不能遇到错误就简单退出,而是继续运行,采用该选项支持内存出错之后程序继续运行,需要叠加设置ASAN_OPTIONS=halt_on_error=0才会生效;若未设置此选项,则内存出错即报错退出

Sanitizer的选项通过环境变量控制,例如

ASAN_OPTIONS=verbosity=1:malloc_context_size=20 ./a.out

其他的选项参考以下内容

ASAN_OPTIONS=help=1 ./a.out

export ASAN_OPTIONS=halt_on_error=0:detect_leaks=1

For the list of common sanitizer options see 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值