使用asan查找程序内存泄露

稍高一些的gcc版本都自带asan了,挺方便的

一、编译

在你的makefile(没有makefile就在gcc后面加就行)中添加以下选项并进行编译

LIBS += -lasan
CXXFLAGS += -fsanitize=address -fno-stack-protector -fno-var-tracking -fno-omit-frame-pointer

二、运行

1.如果直接在终端运行  ./程序名 会提示你(不一定相同,但下列步骤是一样的)

==10987==ASan runtime does not come first in initial library list; you should either link runtime to your application or manually preload it with LD_PRELOAD.

2.你可以find / -name "libasan.so"找到动态库路径   (libasan.so名字会随gcc版本改变,我用gcc 10的时候是libasan.so.6)

3.终端输入下列命令

LD_PRELOAD=/usr/lib/gcc/x86_64-linux-gnu/5/libasan.so  ./你的程序名

   3.1 可能会报错./程序名: /usr/lib/x86_64-linux-gnu/libstdc++.so.6: version `GLIBCXX_3.4.26'               not  found (required by ./你的程序名)           没有则忽略

   3.2 终端输入看有没有需要的GLIBCXX_3.4.26

strings /usr/lib/x86_64-linux-gnu/libstdc++.so.6 | grep GLIBCXX

    3.3  没有则按以下操作(可直接输3,3不行再1 2 3操作一遍)

sudo rm -rf /var/lib/apt/lists/* -vf    
sudo apt-get update
sudo apt-get install libstdc++6

    3.4  再按3.2检查有没有  

4、asan需要程序正常退出才起作用(我是在主循环中加入exit的判断,用来结束程序)
      内存泄露打印会在你运行程序终端打印出来,没有打印表示没检查到问题,每一个错误就是一       个堆栈,很容易找到问题所在

### Android 应用中预防和检测内存泄漏的方法 #### 使用工具进行内存泄漏检测 为了有效检测内存泄漏,可以利用多种工具来辅助开发人员。LeakCanary 是一款专为 Android 设计的流行内存泄漏检测库,能够在应用程序运行期间自动监测并报告任何可能存在的内存泄漏状况[^4]。 对于更深入的原生层内存泄漏排查,则可采用 AddressSanitizer (ASan),这是一种高效的编译时插桩技术,能够帮助定位 C/C++ 代码中的内存错误,包括但不限于缓冲区溢出、非法访问已释放的内存等问题[^3]。 除了上述提到的专业化工具外,Android Studio 自身也集成了强大的 Profiler 工具套件,允许开发者实时跟踪应用性能指标,并支持导出 heap dump 文件以便进一步离线分析[^2]。 #### 编码实践中防止内存泄漏的最佳做法 为了避免因不当编程习惯而导致的内存泄漏现象,在编写 Android 应用程序的过程中应当注意: - **减少不必要的 Context 引用**:尽量避免长时间持有 Activity 或 Application 的实例引用;当确实需要使用时,优先考虑弱引用(WeakReference)或者仅获取 ApplicationContext 而不是具体的 UI 组件上下文。 - **管理好生命周期感知组件**:确保所有注册过的广播接收器(BroadcastReceiver)、监听器(Listener)/回调(Callbacks)都能在其所属对象销毁之前完成注销动作,从而切断不再必要的关联关系。 - **合理运用静态成员变量**:应特别警惕含有指向非静态内部类/匿名内部类的对象作为静态字段的情况,因为这可能会间接造成外部容器(Activity/Fragment)无法正常回收。 - **谨慎对待缓存机制**:如果实现了自定义的数据加载逻辑,请务必设计合理的淘汰策略(LRU Cache 等), 防止无节制增长占用过多 RAM 空间。 通过以上措施结合有效的调试手段,便能显著降低 Android 平台上由内存泄漏引发的各种异常风险,进而提升用户体验质量。 ```java // 示例:正确处理 Handler 和 Runnable 来避免内存泄漏 public class MyActivity extends AppCompatActivity { private final WeakReference<MyActivity> weakThis = new WeakReference<>(this); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 创建 handler 时不直接传入 this,而是传递弱引用 HandlerThread thread = new HandlerThread("MyHandlerThread"); thread.start(); Handler handler = new Handler(thread.getLooper()) { public void handleMessage(Message msg) { MyActivity activity = weakThis.get(); if (activity != null && !activity.isFinishing()) { // 执行具体业务逻辑... } } }; } } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值