android http第三方库,快餐式读完一些Android第三方库

目录

OkHttp

Retrofit

RxJava2

Glide

LeakCanary

LeakCanary2

BlockCanary

Legend

RetrofitUrlManager

Lieric

EventBus(在写)

插件化

Proguard (在写)

Gson

再看还有哪些

OkHttp

1.初始化,用的是Builder建造者模式,把什么SocketFactory啊,HostVerifier啊配置设置好,了解什么是Build模式,挑几个组件看一下

2.发送请求,这里不讲同步,只讲异步

异步就是看equeue的内部实现,比如线程池

3.如何对请求还有响应的处理,这里就是讲Interceptor拦截器,也就是责任链模式,了解责任链模式的好处,及OkHttp用到的几个责任链内部实现。

比如ConnectInterceptor,CacheInterceptor

6.一些应用扩展方面的,比如HttpDns啊,域名容灾啊

延展阅读

Android HttpDns OkHttp踩坑记录

https://www.jianshu.com/p/a0967bed8756

动态切换域名的库RetrofitUrlManager(这个其实是拦截器的应用)

https://www.jianshu.com/p/222b62c06497

Retrofit2.0

1.初始化,也就是实例创建,用的是Builder建造者模式

Retrofit的构造方法是default的,通过静态内部类

Retrofit retrofit = new Retrofit.Builder()

.baseUrl("http://fanyi.youdao.com/")

.addConverterFactory(GsonConverterFactory.create())

.build();

配置好

serviceMethod:包含所有网络请求信息的对象

baseUrl:网络请求的url地址

callFactory:网络请求工厂

adapterFactories:网络请求适配器工厂的集合

converterFactories:数据转换器工厂的集合

callFactory在Retrofit2.0之后是默认OkHttp。

这里是一个外观模式的创建方式,至于怎么生成一个对象

就是这个create方法内部调用Proxy.newProxyInstance方法。

实现接口InvocationHandler。

这个invoke方法里

主要就是生产serviceMethod

这个ServiceMethod是给后边OkHttpCall去用的

调用顺序呢

Retrofit.build.create

ServiceMethod.loadServiceMethod

ServiceMethod.build

内部parseMethodAnnotation方法,把Api.class内的代码根据注解全部解析,解析完之后放到一个Map> 缓存起来。

剩下的网络请求基本跟okhttp一样。

里面

延展阅读

主要讲api的

Android Retrofit 2.0 的详细 使用攻略(含实例讲解)

https://www.jianshu.com/p/a3e162261ab6

Rxjava2

Glide

1.初始化,与Retrofit差不多,外观模式

Glide.with(this).load(url).into(imageView);

with里面传入什么类型的参数决定了这个图片的生命周期。

比如传view,找对应的activty或者fragment,传context去判断是不是applicationContext。

当然,内部还会判断是不是后台线程,是的话也返回getApplicationManager。

如果是applicationContext那么返回getApplicationManager来管理图片生命周,

其余的情况都是attach上一个fragment,监听这个fragment的生命周期来管理图片的生命周期。

2.三级缓存

读取过程在Engine类的load方法里

内部依次

keyFactory.buildKey生成key---提高图片命中率可以从这里入手

EngineResource> active = loadFromActiveResources(key, isMemoryCacheable);---从activeResource拿,本质上是key,weakReference的map

EngineResource> cached = loadFromCache(key, isMemoryCacheable);---从lru拿,拿到就从lru里删除,放到activeResouce里

EngineResource用一个acquired来计数,类似方法计数器。

计数为0就listener.release

diskLru什么时候读

EngineRunnable的run方法内部调用decode方法。

3.内存回收

Application的triLowMem里面有回收方法,

最终都是解析bitmap,原因也是方便recycle内存。

以上两条没深究了。

4.缓存图的key生成方法

EngineKey key = keyFactory.buildKey(id, signature, width, height, loadProvider.getCacheDecoder(),

loadProvider.getSourceDecoder(), transformation, loadProvider.getEncoder(),

transcoder, loadProvider.getSourceEncoder());

LeakCanary

时刻记住,检测Android内存泄漏永远围绕 “对象被引用,无法被GC” 的概念

这个库实际上就是,检查activity的引用,然后导出引用树。

核心原理在 weakReference和weakReferenceQueue的使用,所以一定要充分了解。

何时去注册,何时去dump,在什么线程,这个都是次要的。

LeakCanary 2

Leoric

BlockCanary

说到内存泄漏的库,就不得不提到这个检测卡顿的库。

本质上,就是对Looper.loop方法内的dispatchMsg进行了监听,该库认为卡顿都是有谁阻塞了消息的派发。

这个库的源码也比较简单,一般是会被发散问到 handler的机制。

比如,为什么handler里的sendMsgDelay不会阻塞,为什么loop死循环不会卡UI

前者关健是loop的needAwake字段,后者关键是是pipe管道机制

Legend

免root的hook框架

两个方式调用,注解和api。

通过注解的方式,最终也是调用api方式。

说白了,就是一个灵活调用反射的库,然后把需要反射的方法放入一个map里缓存。

但是又和普通的反射调用不一样,它不是直接invoke调用,

它是构造了一个旧方法的结构体信息,把hook的新数据写进去,然后用Native方法,把这个结构体数据写入内存(实际是指针重新指向这个新的结构体)。

RetrofitUrlManager

这是一个用于动态域名切换的库

本质呢,是利用OkHttp的拦截器完成域名拦截替换的工作,

内部维护三种不同级别的解析器,结合Retrofit的ServiceMethod解析方法(实际上就是注解的方式)解析url,解析完放入cache里。

还提供里两个callback,用来提示替换过程。

EvnetBus

在写这一部分之前,要了解什么是注解,如何使用注解

插件化

这个总结在另一篇了

https://www.jianshu.com/p/9f392c46e670

要重点理解,生命周期如何管理(一般是activity的为主),资源R文件重名怎么办,如何调用插件类。

关键词,hook,classLoader的双亲委派机制,反射原理

实际应用,换肤

https://github.com/hongyangAndroid/ChangeSkin

Proguard

各种工厂类进行参数/方法名替换的工作

没啥好重点的

Gson

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值