UBSan是Clang/GCC的运行时未定义行为检测工具,通过插桩捕获整数溢出、空指针解引用等UB;编译需加-fsanitize=undefined -g -O1,避免高优化等级导致漏检。

UBSan(Undefined Behavior Sanitizer)是Clang和GCC提供的运行时检测工具,专门用来捕获C++中常见的未定义行为(UB),比如有符号整数溢出、空指针解引用、越界数组访问、使用未初始化变量、类型双关(type-punning)违规等。它不依赖静态分析,而是在程序运行时插桩检查,报错直接指向问题代码行,对调试非常友好。
用Clang或较新版本的GCC(≥5.0)编译时加上-fsanitize=undefined即可。推荐同时加-g(保留调试信息)和-O1(开启基础优化,避免UBSan误报或漏报):
clang++ -g -O1 -fsanitize=undefined -o myapp main.cpp
g++ -g -O1 -fsanitize=undefined -o myapp main.cpp
注意:不要用-O2或更高优化等级,某些UB可能被编译器提前优化掉,导致UBSan检测不到;-O1是平衡点。
默认-fsanitize=undefined只启用一部分检查(如整数溢出、移位越界、null指针解引用)。你可以按需启用更细粒度的检查:
立即学习“C++免费学习笔记(深入)”;
INT_MAX + 1)delete nullptr
x 当x是32位整数)
__builtin_unreachable()标记的不可达路径memcpy/memmove越界(需配合-D_FORTIFY_SOURCE=2)多个选项可用逗号拼接,例如:-fsanitize=signed-integer-overflow,null,shift。
UBSan默认在触发UB时打印详细错误信息并终止程序。你可以通过环境变量微调行为:
abort()退出(便于gdb调试)示例运行命令:UBSAN_OPTIONS=print_stacktrace=1:abort_on_error=1 ./myapp。
UBSan不是万能的,使用时需注意:
thread sanitizer)不在UBSan范围内,应搭配TSan使用基本上就这些。UBSan上手简单,效果直接,是C++调试未定义行为最实用的工具之一。
以上就是C++的Undefined Behavior Sanitizer怎么用?UBSan检测C++未定义行为【调试】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号