AddressSanitizer简介


AddressSanitizer 是一个快速的内存错误检测工具,它由一个编译时插桩模块和一个运行库组成。该工具可以检测以下类型的错误:

  • 堆、栈和全局变量的越界
  • UAF
  • Use-After-Return(runtime flag ASAN_OPTIONS=detect_stack_use_after_return=1)
  • Use-After-Scope(clang flag -fsanitize-address-use-after-scope)
  • Doube-Free
  • Memory Leaks

AddressSanitizer会降低程序性能大于两倍(相比之前内存检查工具已经有了很大提升)

原理

https://blog.csdn.net/pang241/article/details/76137969

https://github.com/google/sanitizers/wiki/AddressSanitizerAlgorithm


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM