首先我们得先熟悉下 OkHttp 同步请求的流程 ===>可以看下上篇文章OkHttp同步请求
接下来我们直接从创建 OkHttpClient 中开始查看。
通过查看源码我们知道了创建 OkHttpClient 对象,实际上是 OkHttpClient 中静态类 Builder 的 Builder() 的构造方法先初始化了一些参数和对象(这些参数对象会在后面的请求流程中会用到),
再通过调用 OkHttpClient 自己的 build()方法将初始化好了的 Builder 对象赋值给本身,从而创建出了一个客服端的OkHttpClient对象。
- 当我们创建一个对象时,如果这个对象需要很多参数,这个时候我们也可以用到Builder这种创建模式。
用 Builder 对象来封装我们初始化对象所需要的参数,然后传递这个Builder对象到初始化对象构造方法里,完成整个初始化对象属性的初始化。
然后从创建 Request 中开始查看。
查看源码我们知道了创建 Request 对象,实际上也是 Request 中静态类 Builder 的 Builder() 的构造方法先初始化了一些参数,默认了请求方式为 get
再通过调用 Request 自己的 build()方法将初始化好了的 Builder 对象赋值给本身,从而创建出了一个客服端的Request对象。
- 可以发现 OkHttpClient 和 Request 都是用的Builder这种创建模式
创建 Call 对象
实际上是通过创建好了的 OkHttpClient 对象调用 newCall(Request request) 方法来封装创建好的 Request 对象,从而得到Call对象。
//第三步创建 Call对象
Call call=client.newCall(request);
Call 通过查看源码发现 Call 只是一个接口,再从 newCall() 去查看源码,由于 Call 是一个接口,所以 Call 的实际操作都是在 Call 的实现类 RealCall 中所做的。
RealCall 到底又做了什么呢?我们可以点进 RealCall 的构造方法源码去看看
- OkHttp中不管是同步请求还是异步请求,都是通过 OkHttpClient 对象调用 newCall(Request request) 方法来进行创建的,然后再通过创建好的 Call 对象来进行相应的操作。
接下来就走到了第四步 Call.execute()完成同步请求
//第四步 通过call 对象调用同步异步的调用
Response response = call.execute();
接下来我们还是到 execute() 方法去查看源码。由于Call是个接口,所以还是得到 Call的实现类 RealCall 中进行查看。
在源码中我们看到了同步请求的重要的一个环节代码
try {
client.dispatcher().executed(this);
Response result = getResponseWithInterceptorChain();
if (result == null) throw new IOException("Canceled");
return result;
} catch (IOException e) {
eventListener.callFailed(this, e);
throw e;
} finally {
client.dispatcher().finished(this);
}
我们先通过源码知道
是得到 OkHttpClient 中初始化好的的 dispatcher 分发器对象
然后我们再到
我们可以通过同步请求队列 runninSyncCalls 点击上去发现有多种请求队列
接下来就是返回响应信息
由于同步异步这一块是一样的,所以下一章节异步详细说明。
我们最后来看源码中最后的一句代码
我们可以点击进去看下它怎么实现的
- 我们可以发现在同步请求中 Dispatcher 做的事就很少,就是添加同步请求,移除同步请求。然而在异步请求中 Dispatcher 做的事就很多了。
至此我们的OkHttp的同步请求源码分析已经完成了