操作步骤及现象:
应用程序在播放视频时点击Home键,应用程序被主页覆盖,运行于后台,再一次点击应用程序图标,程序崩溃,报错如下:
FATAL EXCEPTION: main
java.lang.RuntimeException: Canvas: trying to use a recycled bitmap android.graphics.Bitmap@41434a00
at android.graphics.Canvas.throwIfRecycled(Canvas.java:1038)
at android.graphics.Canvas.drawBitmap(Canvas.java:1142)
at android.graphics.drawable.BitmapDrawable.draw(BitmapDrawable.java:393)
at android.widget.ImageView.onDraw(ImageView.java:892)
at android.view.View.draw(View.java:11180)
at android.view.ViewGroup.drawChild(ViewGroup.java:2895)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.View.draw(View.java:11183)
at android.widget.FrameLayout.draw(FrameLayout.java:450)
at android.view.ViewGroup.drawChild(ViewGroup.java:2895)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.View.draw(View.java:11183)
at android.view.ViewGroup.drawChild(ViewGroup.java:2895)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.View.draw(View.java:11183)
at android.widget.FrameLayout.draw(FrameLayout.java:450)
at android.view.ViewGroup.drawChild(ViewGroup.java:2895)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.ViewGroup.drawChild(ViewGroup.java:2893)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2497)
at android.view.View.draw(View.java:11183)
at android.widget.FrameLayout.draw(FrameLayout.java:450)
at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:2295)
at android.view.ViewRootImpl.draw(ViewRootImpl.java:2231)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1837)
at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2649)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4512)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:978)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:745)
at dalvik.system.NativeStart.main(Native Method)
问题原因:
点击home键时执行Activity生命周期中的OnStop(),而我在这方法里面执行了释放代码:
if (bitmap != null && (!bitmap.isRecycled()))
{
bitmap.recycle();
}
于是再次进入此界面时就出现如上错误。