//运行期生成一个实现WanApi接口的类(字节码),并反射创建其实例
WanApi wanApi = retrofit.create(WanApi.class);
//得到Retrofit的call,他封装了okhttp的call
Call call = wanApi.articleList(0);
//请求入队
call.enqueue(new Callback() {
@Override
public void onResponse(Call call, Response response) {
//得到数据实体
WanArticleBean bean = response.body();
//不同于okhttp,Retrofit已经用Handler帮我们切回主线程了
mBinding.tvResult.setText("" + bean.getData().getDatas().size());
}
@Override
public void onFailure(Call call, Throwable t) {}
});
}
}
实现原理
由于Retrofit底层基于okhttp,哈迪在《看完不忘系列》之okhttp已经对网络流程做了分析,所以本文忽略网络实现只关注Retrofit自身的一些处理,Retrofit对象的构建就是简单的builder模式,我们直接看create,
//Retrofit.java
public T create(final Class service) {
//验证
validateServiceInterface(service);
return (T)
//动态代理
Proxy.newProxyInstance(
service.getClassLoader(), //类加载器
new Class<?>[] {service}, //一组接口
new InvocationHandler() {
//判断android和jvm平台及其版本
private final Platform platform = Platform.get();
@Override
public Object invoke(Object proxy, Method method, Object[] args){
//如果该方法是Object的方法,直接执行不用管
if (method.getDeclaringClass() == Object.class) {
return method.invoke(this, args);
}
//isDefaultMethod:检查是否是java8开始支持的接口默认方法
return platform.isDefaultMethod(method)
? platform.invokeDefaultMethod(method, service, proxy, args)
: loadServiceMethod(method).invoke(args); //我们关注这里
}
});
}
Proxy.newProxyInstance动态代理,运行期会生成一个类(字节码)如$ProxyN
,实现传入的接口即WanApi
,重写接口方法然后转发给InvocationHandler的invoke,如下(伪代码),
class $ProxyN extends Proxy implements WanApi{
Call articleList(@Path(“page”) int page){
//转发给invocationHandler
invocationHandler.invoke(this,method,args);
}
}
我们先看validateServiceInterface验证逻辑,
//Retrofit.java
private void validateServiceInterface(Class<?> service) {
//检查:WanApi不是接口就抛异常…
//检查:WanApi不能