非要问Glide的源码吗?不会 会影响我开发吗?
16年时候会布局会简单的listView 咱就能工作了,现在非要这么卷吗?
问你缓存策略,问你生命周期、问你里面各中设计模式 都是同行为什么要这样死逼呢?
Glide的缓存
简单的使用:
Glide.with(this).load("").into(null)
先简单的记 with是绑定页面生命周期(防止内存泄露) load 是构建请求(像 okhttp 构建Request一样) into方法就像okhttp client执行enqueue方法一样
那么缓存我们就从into方法看 前面的先不看 因为咱们主要是看缓存
注意这里的Target 我们把它作一个回调(像okhttp 的 CallBack一样)
data:image/s3,"s3://crabby-images/0abef/0abef84d6302ac237a43ff604ef8ccc089cfcd15" alt=""
image.png
data:image/s3,"s3://crabby-images/beacf/beacf9e95ebd01c03885afc0e50da41e807eb29d" alt=""
image.png
我们进入到super.into(view)
data:image/s3,"s3://crabby-images/c9481/c9481abc22dc22e7d785ba18c0bfde50867d8ef3" alt=""
image.png
data:image/s3,"s3://crabby-images/ac7a6/ac7a669c54abaffc780e2889dc43f75316f5e875" alt=""
image.png
data:image/s3,"s3://crabby-images/0cbb8/0cbb8fc89a00d764cca57751bf6e077c401afc4d" alt=""
image.png
注意这里 (看英文意思 开始请求)
data:image/s3,"s3://crabby-images/40247/40247f9ce93c2964ef1ca9683c78fef67732f4d1" alt=""
image.png
这里Request是一个接口
data:image/s3,"s3://crabby-images/d2baa/d2baabca23575f7084a081208f02ea8522a71307" alt=""
image.png
我们找它的实现类:GenericRequest
data:image/s3,"s3://crabby-images/a6f4b/a6f4b7e1ad9668540d7edce2d532860359f08f38" alt=""
image.png
data:image/s3,"s3://crabby-images/1fa09/1fa0960891d7b760b03b6f6a688f31e1ac5af604" alt=""
image.png
data:image/s3,"s3://crabby-images/48851/48851f2259b83482e173f4866ecacd95fef8881d" alt=""
image.png
至此我们找到了入口
data:image/s3,"s3://crabby-images/33056/33056f474a3aff2dc697399f91243e97fe1775e4" alt=""
image.png