OkHttp3源码详解(三) 拦截器,PDF超过6000页,

  1. }

  2. @Override

  3. public void onResponse(Call call, Response response) throws IOException {

  4. Log.d(“OkHttp”, “Call succeeded:” + response.message());

  5. }

  6. });

2. 发起请求

OkHttpClient.newCall实际是创建一个RealCall实例:

  1. @Override

  2. public Call newCall(Request request) {

  3. return new RealCall(this, request, false /* for web socket */);

  4. }

RealCall.enqueue实际就是讲一个RealCall放入到任务队列中,等待合适的机会执行:

  1. @Override

  2. public void enqueue(Callback responseCallback) {

  3. synchronized (this) {

  4. if (executed) throw new IllegalStateException(“Already Executed”);

  5. executed = true;

  6. }

  7. captureCallStackTrace();

  8. client.dispatcher().enqueue(new AsyncCall(responseCallback));

  9. }

从代码中可以看到最终RealCall被转化成一个AsyncCall并被放入到任务队列中,任务队列中的分发逻辑这里先不说,相关实现会放在OkHttp源码分析——任务队列疑问进行介绍。这里只需要知道AsyncCall的excute方法最终将会被执行:

  1. [RealCall.java]

  2. @Override protected void execute() {

  3. boolean signalledCallback = false;

  4. try {

  5. Response response = getResponseWithInterceptorChain();

  6. if (retryAndFollowUpInterceptor.isCanceled()) {

  7. signalledCallback = true;

  8. responseCallback.onFailure(RealCall.this, new IOException(“Canceled”));

  9. } else {

  10. signalledCallback = true;

  11. responseCallback.onResponse(RealCall.this, response);

  12. }

  13. } catch (IOException e) {

  14. if (signalledCallback) {

  15. // Do not signal the callback twice!

  16. Platform.get().log(INFO, "Callback failure for " + toLoggableString(), e);

  17. } else {

  18. responseCallback.onFailure(RealCall.this, e);

  19. }

  20. } finally {

  21. client.dispatcher().finished(this);

  22. }

  23. }

  24. }

execute方法的逻辑并不复杂,简单的说就是:

调用getResponseWithInterceptorChain获取服务器返回

通知任务分发器(client.dispatcher)该任务已结束

getResponseWithInterceptorChain构建了一个拦截器链,通过依次执行该拦截器链中的每一个拦截器最终得到服务器返回。

3. 构建拦截器链

首先来看下getResponseWithInterceptorChain的实现:

源码路径:okhttp3/RealCall.java

// 开始执行整个请求

Response getResponseWithInterceptorChain() throws IOException {

// Build a full stack of interceptors.

// 拦截器栈

List interceptors = new ArrayList<>();

// 前文说过的 普通拦截器

interceptors.addAll(client.interceptors());

// 重试拦截器,网络错误、请求失败等

interceptors.add(retryAndFollowUpInterceptor);

// 桥接拦截器,主要是重构请求头即header

interceptors.add(new BridgeInterceptor(client.cookieJar()));

// 缓存拦截器

interceptors.add(newCacheInterceptor(client.internalCache()));

// 连接拦截器,连接服务器,https包装

interceptors.add(new ConnectInterceptor(client));

// 网络拦截器,websockt不支持,同样是自定义

if (!forWebSocket) {

interceptors.addAll(client.networkInterceptors());

}

// 服务拦截器,主要是发送(write、input)、读取(read、output)数据

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

最后

希望大家能有一个好心态,想进什么样的公司要想清楚,并不一定是大公司,我选的也不是特大厂。当然如果你不知道选或是没有规划,那就选大公司!希望我们能先选好想去的公司再投或内推,而不是有一个公司要我我就去!还有就是不要害怕,也不要有压力,平常心对待就行,但准备要充足。最后希望大家都能拿到一份满意的 offer !如果目前有一份工作也请好好珍惜好好努力,找工作其实挺累挺辛苦的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。可以点击GitHub免费获取

试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。可以点击GitHub免费获取

[外链图片转存中…(img-eaV3sGp9-1710846290295)]

  • 24
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值