2017-12-18 41 views
2

볼 수 안드로이드 8.0에안드로이드 : java.lang.IllegalStateException : 안드로이드에 재활용 비트 맵 (글라이드)을 풀 수없는 것은 8.0

(4.3.1 글라이드) 나는들의 OnDestroy()가 호출이 충돌이 있습니다

Fatal Exception: java.lang.RuntimeException: Unable to destroy activity {com.xxx/com.xxx.ui.photo.PhotoActivity}: java.lang.IllegalStateException: Cannot pool recycled bitmap 
     at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:4993) 
     at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:5012) 
     at android.app.ActivityThread.-wrap6(Unknown Source) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1944) 
     at android.os.Handler.dispatchMessage(Handler.java:108) 
     at android.os.Looper.loop(Looper.java:166) 
     at android.app.ActivityThread.main(ActivityThread.java:7358) 
     at java.lang.reflect.Method.invoke(Method.java) 
     at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:926) 
Caused by java.lang.IllegalStateException: Cannot pool recycled bitmap 
     at com.bumptech.glide.load.engine.bitmap_recycle.LruBitmapPool.put(LruBitmapPool.java:86) 
     at com.bumptech.glide.load.resource.bitmap.BitmapResource.recycle(BitmapResource.java:57) 
     at com.bumptech.glide.load.engine.EngineResource.recycle(EngineResource.java:63) 
     at com.bumptech.glide.load.engine.ResourceRecycler.recycle(ResourceRecycler.java:28) 
     at com.bumptech.glide.load.engine.Engine.onResourceReleased(Engine.java:336) 
     at com.bumptech.glide.load.engine.EngineResource.release(EngineResource.java:101) 
     at com.bumptech.glide.load.engine.Engine.release(Engine.java:292) 
     at com.bumptech.glide.request.SingleRequest.releaseResource(SingleRequest.java:337) 
     at com.bumptech.glide.request.SingleRequest.clear(SingleRequest.java:316) 
     at com.bumptech.glide.manager.RequestTracker.clearRemoveAndRecycle(RequestTracker.java:62) 
     at com.bumptech.glide.RequestManager.untrack(RequestManager.java:462) 
     at com.bumptech.glide.RequestManager.untrackOrDelegate(RequestManager.java:449) 
     at com.bumptech.glide.RequestManager.clear(RequestManager.java:437) 
     at com.bumptech.glide.RequestManager.onDestroy(RequestManager.java:290) 
     at com.bumptech.glide.manager.ActivityFragmentLifecycle.onDestroy(ActivityFragmentLifecycle.java:64) 
     at com.bumptech.glide.manager.SupportRequestManagerFragment.onDestroy(SupportRequestManagerFragment.java:187) 
     at android.support.v4.app.Fragment.performDestroy(Fragment.java:2516) 
     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1557) 
     at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1750) 
     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1819) 
     at android.support.v4.app.FragmentManagerImpl.dispatchStateChange(FragmentManager.java:3227) 
     at android.support.v4.app.FragmentManagerImpl.dispatchDestroy(FragmentManager.java:3218) 
     at android.support.v4.app.FragmentController.dispatchDestroy(FragmentController.java:262) 
     at android.support.v4.app.FragmentActivity.onDestroy(FragmentActivity.java:362) 
     at android.support.v7.app.AppCompatActivity.onDestroy(AppCompatActivity.java:209) 
     at com.xxx.ui.BaseActivity.onDestroy(BaseActivity.java:307) 
     at com.xxx.ui.photo.PhotoActivity.onDestroy(PhotoActivity.java:164) 
     at android.app.Activity.performDestroy(Activity.java:7572) 
     at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1253) 
     at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:4980) 
     at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:5012) 
     at android.app.ActivityThread.-wrap6(Unknown Source) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1944) 
     at android.os.Handler.dispatchMessage(Handler.java:108) 
     at android.os.Looper.loop(Looper.java:166) 
     at android.app.ActivityThread.main(ActivityThread.java:7358) 
     at java.lang.reflect.Method.invoke(Method.java) 
     at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:926) 

이 충돌이 발생한 것은 처음입니다. 설명이 있니? http://bumptech.github.io/glide/doc/resourcereuse.html#common-errors을 확인했는데이 충돌에 대해 아무 것도 보지 못했습니다.

Ps : Android 4 ~ 7에서 충돌이 발생하지 않습니다.

대단히 감사합니다!

답변

1

이 오류는 비트 맵이 재활용 되었기 때문에 발생하지만 여전히 Resource<Bitmap>에서 사용 된 것으로 생각됩니다. source.recycle();을 삭제 해보세요.

+0

8.0을 제외한 다른 Android SDK에서 왜 문제가되는지 설명 할 수 있습니까? – anthony

+0

전에 문제가 발생하여 source.recycle() 추적을 제거했습니다. 그리고 효과가있었습니다. 그 외에는 철저히 테스트하지 않은 경험으로 말할 수 없습니다. –

+0

당신은 말했습니다 : 글라이드에서 사용하는 모든 자원 (비트 맵)은 재활용해서는 안됩니다 (src.recycle()); 권리? – anthony