android 如何分析java.lang.IllegalArgumentException: Cannot draw recycled bitmaps异常
2014-10-13 10:49
519 查看
该类问题的分析,一般是需要找到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中搜索关键字 “@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)
......
如何定位到是在哪个代码位置有把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中搜索关键字 “@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)
......
相关文章推荐
- 如何分析java.lang.IllegalArgumentException: Cannot draw recycled bitmaps异常
- Android IllegalArgumentException: Cannot draw recycled bitmaps解决方法
- Android IllegalArgumentException: Cannot draw recycled bitmaps解决方法
- android 如何分析java.lang.IllegalArgumentException: Cannot draw recycled bitmaps异常
- IllegalArgumentException: Cannot draw recycled bitmaps
- Android异常总结---E/AndroidRuntime(23439): Caused by: java.lang.IllegalArgumentException: column '_id' d
- 关于Strust的异常信息:java.lang.IllegalArgumentException: Resources cannot be null.
- java.lang.IllegalArgumentException: hostname can't be null这个异常的解决办法分析
- Android 中 java.lang.IllegalArgumentException: pointerIndex out of range 异常的处理方法
- 如何解决Mybatis--java.lang.IllegalArgumentException: Result Maps collection already contains value for X
- 如何分析java.lang.IllegalArgumentException: Cannot draw recycled bitmaps异常
- Android 异常处理:java.lang.IllegalArgumentException(...contains a path separator)
- [zhuan]Android 异常处理:java.lang.IllegalArgumentException(...contains a path separator)
- Android异常总结---E/AndroidRuntime(23439): Caused by: java.lang.IllegalArgumentException: column '_id' d
- 使用Android提供的模拟任意地理位置,报java.lang.IllegalArgumentException: Incomplete location object异常的解决方法
- Android学习----异常(3)---java.lang.IllegalArgumentException: column '_id' does not exist
- AndroidStudio启动异常:Caused by: java.lang.IllegalArgumentException: Argument for @NotNull paramet
- android java.lang.IllegalArgumentException: The observer is null.异常解决
- Android异常总结---1.异常原因: java.lang.IllegalArgumentException: URI: content://com.android.contacts/con
- 异常:java.lang.IllegalArgumentException: Result Maps collection already contains ...