最新OkHttp3源码详解之拦截器(四),Java入门

最后

现在其实从大厂招聘需求可见,在招聘要求上有高并发经验优先,包括很多朋友之前都是做传统行业或者外包项目,一直在小公司,技术搞的比较简单,没有怎么搞过分布式系统,但是现在互联网公司一般都是做分布式系统。

所以说,如果你想进大厂,想脱离传统行业,这些技术知识都是你必备的,下面自己手打了一份Java并发体系思维导图,希望对你有所帮助。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  1. Log.d(“OkHttp”, “Call Failed:” + e.getMessage());

  2. }

  3. @Override

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

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

  6. }

  7. });

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)数据
interceptors.add(new CallServerInterceptor(forWebSocket));

// 开启调用链
Interceptor.Chain chain = new RealInterceptorChain(
interceptors, , originalRequest);
return chain.proceed(originalRequest);
}

其逻辑大致分为两部分:

创建一系列拦截器,并将其放入一个拦截器数组中。这部分拦截器即包括用户自定义的拦截器也包括框架内部拦截器
创建一个拦截器链RealInterceptorChain,并执行拦截器链的proceed方法
接下来看下RealInterceptorChain的实现逻辑:

public final class RealInterceptorChain implements Interceptor.Chain {
private final List interceptors;
private final StreamAllocation streamAllocation;
private final HttpCodec httpCodec;
private final RealConnection connection;
private final int index;
private final Request request;
private int calls;

面试题总结

其它面试题(springboot、mybatis、并发、java中高级面试总结等)

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

forums/4f45ff00ff254613a03fab5e56a57acb)收录**

需要这份系统化的资料的朋友,可以点击这里获取

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值