小超小调 2023-08-09 10:05 采纳率: 52.6%
浏览 19
已结题

android开发长时间抓取log报错OutOfMemoryError

img

android开启线程执行Runtime.getRuntime().exec("logcat")去获取android log
线程会不断BufferedReader.readLine,前面抓取log是正常的,当线程一直运行大概2小时会报错

E AndroidRuntime: java.lang.OutOfMemoryError: Failed to allocate a 88 byte allocation with 0 free bytes and 0B until OOM, target footprint 201326592, growth limit 201326592

分析log是BufferedReader.readLine这里的问题,不可以循环去readline?还是需要每读一次readLine就要close掉资源?
帮忙看看代码写的是不是合理的,还有问题的解决办法

  • 写回答

2条回答 默认 最新

  • 立青_ 2023-08-09 10:24
    关注

    循环readLine并不会导致内存溢出;你output方法做了什么

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月25日
  • 已采纳回答 8月17日
  • 创建了问题 8月9日