问题描述
我正在使用LeakCanary来帮助检测泄漏,并且不断收到这一泄漏,但我不知道为什么会发生。
我有一个FragmentStatePagerAdapter,它使用其默认的屏幕外限制(每一面都加载一个)。
我在片段中所拥有的全部就是使用Glide加载图像。
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater,@Nullable ViewGroup container,@Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_viewpager_image_view,container,false);
ButterKnife.bind(this,view);
Glide.with(mContext).load(mUrl)
.apply(RequestOptions.centerInsideTransform())
.listener(new RequestListener<Drawable>() {
@Override
public boolean onLoadFailed(@Nullable GlideException e,Object model,Target<Drawable> target,boolean isFirstResource) {
mProgressBar.setVisibility(View.INVISIBLE);
errorImageView.setVisibility(View.VISIBLE);
errorTextView.setVisibility(View.VISIBLE);
Glide.with(mContext)
.load(R.drawable.snail)
.apply(RequestOptions.centerInsideTransform())
.into(errorImageView);
String text = "Failed to load image \n" + mUrl;
errorTextView.setText(text);
return false;
}
@Override
public boolean onResourceReady(Drawable resource,DataSource dataSource,boolean isFirstResource) {
mProgressBar.setVisibility(View.INVISIBLE);
return false;
}
})
.into(mImage);
return view;
}
每次我滚动时,LeakCanary消息不会弹出,因此令人沮丧,因为我无法指出如何重新创建错误。在LeakCanary消息弹出之前,我可以滚动并加载30-50张图像。
├─ e.com.app.ui.viewpager.ViewpagerImageFragment$1 instance
│ Leaking: UNKNowN
│ Anonymous class implementing com.bumptech.glide.request.RequestListener
│ ↓ ViewpagerImageFragment$1.this$0
│ ~~~~~~
╰→ e.com.app.ui.viewpager.ViewpagerImageFragment instance
Leaking: YES (ObjectWatcher was watching this because e.com.app.ui.viewpager.ViewpagerImageFragment received Fragment#onDestroy() callback and Fragment#mFragmentManager is null)
key = 3e232914-78d0-457c-9ca5-c6e9c8f92c55
watchDurationMillis = 7300
retainedDurationMillis = 2300
key = f745901e-5222-42db-b594-f07a47b84788
究竟是什么原因导致泄漏?
解决方法
使用Glide.with(this)
,其中this
是Fragment实例,您的Glide请求将与Fragment生命周期绑定,而不是Activity。