zoukankan      html  css  js  c++  java
  • android 如何分析java.lang.IllegalArgumentException: Cannot draw recycled bitmaps异常

    这类问题的分析,通常你需要找到bitmap对象已经在那个位置recyle,然后检查代码。


    如何定位的位置,其中代码具有对bitmap 目的recyle。能够 Bitmap.java的recycle方法,加log打印call stack要找到。
     
    详细的改动參考例如以下:
     
     public void recycle() {
            if (!mRecycled) {
                if (nativeRecycle(mNativeBitmap)) {
                    // return value indicates whether native pixel object was actually recycled.
                    // false indicates that it is still in use at the native level and these
                    // objects should not be collected now. They will be collected later when the
                    // Bitmap itself is collected.
                    mBuffer = null;
                    mNinePatchChunk = null;
                }
                mRecycled = true;
               
                log.e("bitmap recyle! ", "this = " + this ,new Throwable("recycle"));


            }
        }
     
    然后在抛 java.lang.IllegalArgumentException: Cannot draw recycled bitmaps 异常的地方,也将bitmap 对象打印出来。 抓取复现问题的mobile log 分析。


     
    比如例如以下的log:
     
    在main log中搜索“FATAL EXCEPTION”看到发生fatal error exception的 trace例如以下。相应的bitmap对象为 android.graphics.Bitmap@4218d0c8
    01-01 08:03:23.841  2369  2369 D AndroidRuntime: Shutting down VM
    01-01 08:03:23.841  2369  2369 W dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x40f979a8)
    01-01 08:03:23.856  2369  2369 E AndroidRuntime: FATAL EXCEPTION: main
    01-01 08:03:23.856  2369  2369 E AndroidRuntime: java.lang.IllegalArgumentException: Cannot draw recycled bitmapsandroid.graphics.Bitmap@4218d0c8
    然后再在main log中搜索keyword “@4218d0c8” ,就能够看到该对象被recyle的call stack
     
    01-01 08:03:22.741  2369  2369 E bitmap recyle! : this = android.graphics.Bitmap@4218d0c8
    01-01 08:03:22.741  2369  2369 E bitmap recyle! : java.lang.Throwable: recycle
    01-01 08:03:22.741  2369  2369 E bitmap recyle! :  at android.graphics.Bitmap.recycle(Bitmap.java:214)
    01-01 08:03:22.741  2369  2369 E bitmap recyle! :  at com.xxx.xxxx.xxxActivity.onDestroy(xxxActivity.java:190)
    01-01 08:03:22.741  2369  2369 E bitmap recyle! :  at android.app.Fragment.performDestroy(Fragment.java:1908)
    ......

  • 相关阅读:
    Dumpbin 工具的使用
    ffmpeg Windows下采集摄像头一帧数据,并保存为bmp图片
    directdraw显示yuv视频,出现屏保时,yuv显示不出来,表面丢失
    DirectX截图黑屏的解决办法
    VS2008 Project : error PRJ0019: 某个工具从以下位置返回了错误代码: "正在执行生成后事件..."解决方案
    RoundingMode 几个参数详解
    IDEA导入eclipse项目并部署运行完整步骤(转发)
    Intellij idea操作maven时控制台中文乱码
    java 替换json字符串中间的引号保留两边的引号,避免json校验失败
    分布式ID解决方案
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/5044695.html
Copyright © 2011-2022 走看看