日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

AddressSanitizer 查找內存問題

作者:newrtc 更新時間: 2023-10-15 編程語言

服務器開發,有些時候遇到很奇怪的問題,可能運行幾個周會出現一次異常,有些內存問題可以借助AddressSanitizer 定位

centos g++版本切換

https://blog.csdn.net/liuhongxiangm/article/details/124129742
這個方法只是臨時生效
我是在.bashrc里加了

source /opt/rh/devtoolset-10/enable

AddressSanitizer

AddressSanitizer 是一個性能非常好的C/C++ 內存錯誤探測工具。
它由編譯器的插樁模塊和替換了malloc函數的運行時庫組成。
這個工具可以探測如下這些類型的錯誤:

  • 對堆、棧和全局內存的訪問越界(堆緩沖區溢出,棧緩沖區溢出,和全局緩沖區溢出)
  • UAP(Use-after-free,懸掛指針的解引用,或者說野指針)
  • Use-after-return(無效的棧上內存,運行時標記 ASAN_OPTIONS=detect_stack_use_after_return=1)
  • Use-After-Scope (作用域外訪問,clang標記-fsanitize-address-use-after-scope)
  • 內存的重復釋放 (double-free)
  • 初始化順序的BUG
  • 內存泄漏 (memory leak)

使用

1、以CentOS7環境下編譯器gcc 10為例 (版本支持: gcc version > 4.8)
下載地址:
https://centos.pkgs.org/7/centos-sclo-rh-x86_64/
https://centos.pkgs.org/7/centos-sclo-rh-x86_64/devtoolset-10-libasan-devel-10.2.1-11.2.el7.x86_64.rpm.html
或者

yum install centos-release-scl-rh
yum install devtoolset-10-libasan-devel

這個要和gcc 版本對應
2、編譯源碼的時候只需要加上以下編譯參數即可:

-fsanitize=address -fno-omit-frame-pointer -g

鏈接庫:-lasan

項目經驗

  • 項目的構建方案應當有編譯選項可以隨時啟用/關閉ASAN
  • 項目送測階段可以打開ASAN以幫助暴露更多的低概率詭異問題
  • 請勿在生產版本中啟用ASAN, 其會降低程序運行速度大概2-5倍 (特殊情況除外)
  • 實際開發測試過程中通過ASAN掃出的常見問題有:
  • 多線程下臨界資源未加保護導致同時出現讀寫訪問, 解決方案一般是對該資源恰當地加鎖即可
  • 內存越界, 如申請了N字節的內存卻向其內存地址拷貝大于N字節的數據, 這種情況在沒有開啟ASAN的情況下一般都很難發現

原文鏈接:https://newrtc.blog.csdn.net/article/details/124426529

  • 上一篇:沒有了
  • 下一篇:沒有了
欄目分類
最近更新