shibafu528/Yukari

TLを見ていると `trying to use a recycled bitmap` で落ちる

Closed this issue · 2 comments

TLを見ているだけで落ちることがある。

backtrace

java.lang.RuntimeException: Canvas: trying to use a recycled bitmap android.graphics.Bitmap@58fc964
	at android.graphics.BaseCanvas.throwIfCannotDraw(BaseCanvas.java:74)
	at android.graphics.RecordingCanvas.throwIfCannotDraw(RecordingCanvas.java:263)
	at android.graphics.BaseRecordingCanvas.drawBitmap(BaseRecordingCanvas.java:94)
	at android.graphics.drawable.BitmapDrawable.draw(BitmapDrawable.java:549)
	at android.widget.ImageView.onDraw(ImageView.java:1446)
	at android.view.View.draw(View.java:23209)
	at android.view.View.updateDisplayListIfDirty(View.java:22076)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.draw(View.java:23212)
	at android.view.View.updateDisplayListIfDirty(View.java:22076)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.widget.ListView.drawChild(ListView.java:3613)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.widget.AbsListView.dispatchDraw(AbsListView.java:2735)
	at android.widget.ListView.dispatchDraw(ListView.java:3608)
	at android.view.View.draw(View.java:23212)
	at android.widget.AbsListView.draw(AbsListView.java:4527)
	at android.view.View.updateDisplayListIfDirty(View.java:22076)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.draw(View.java:23212)
	at android.view.View.updateDisplayListIfDirty(View.java:22076)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.draw(View.java:23212)
	at androidx.viewpager.widget.ViewPager.draw(ViewPager.java:2426)
	at android.view.View.updateDisplayListIfDirty(View.java:22076)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.updateDisplayListIfDirty(View.java:22067)
	at android.view.View.draw(View.java:22940)
	at android.view.ViewGroup.drawChild(ViewGroup.java:4529)
	at android.view.ViewGroup.dispatchDraw(ViewGroup.java:4290)
	at android.view.View.draw(View.java:23212)
	at com.android.internal.policy.DecorView.draw(DecorView.java:836)
	at android.view.View.updateDisplayListIfDirty(View.java:22076)
	at android.view.ThreadedRenderer.updateViewTreeDisplayList(ThreadedRenderer.java:682)
	at android.view.ThreadedRenderer.updateRootDisplayList(ThreadedRenderer.java:688)
	at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:786)
	at android.view.ViewRootImpl.draw(ViewRootImpl.java:4582)
	at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:4293)
	at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:3520)
	at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:2289)
	at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:8958)
	at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1319)
	at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1327)
	at android.view.Choreographer.doCallbacks(Choreographer.java:985)
	at android.view.Choreographer.doFrame(Choreographer.java:916)
	at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:1302)
	at android.os.Handler.handleCallback(Handler.java:942)
	at android.os.Handler.dispatchMessage(Handler.java:99)
	at android.os.Looper.loopOnce(Looper.java:346)
	at android.os.Looper.loop(Looper.java:475)
	at android.app.ActivityThread.main(ActivityThread.java:7950)
	at java.lang.reflect.Method.invoke(Native Method)
	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:548)
	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:942)

おそらくこの recycle() が原因。直前の処理でBitmapCache (オンメモリキャッシュ) に格納したBitmapインスタンスを解放している。

//キャッシュに保存
BitmapCache.putImage(param.url, image, context, param.cacheKey);
}
if (image != null && param.mosaic) {
Bitmap mosaicBitmap = BitmapUtil.createMosaic(image);
image.recycle();
image = mosaicBitmap;
}

git blameが正しければ #1 で導入された9年もののバグ。