源码解析,okhttp3中的异步请求enqueue()

本文详细解析了OkHttp3中的异步请求机制,包括如何通过调度器(dispatcher)控制并发请求的数量,以及如何使用AsyncCall进行异步请求的执行过程。通过源码分析,介绍了OkHttp3内部如何利用队列管理和执行请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对应的jar包

okhttp-3.3.0.jar okio-1.8.0.jar

首先这是一个简单的okhttp3的异步请求,先创建参数对象,然后异步请求返回值

接着我们来分析enqueue

在Call.class 中找到方法

接着找到实现方法在类RealCall.class中

Part1.

这里可以看到synchronized ,第一个悲观锁,这是为了确保当前的请求只有一个(对应的一个方法中的请求执行只有一个,但是有多个异步方法调用进来时则不受限制)

 

做完锁的判断后,就执行okHttpClient 的调度器(dispatcher是okhttp自己定义的一个调度器)

这个方法中有两个判断,第一个是根据maxRequests就是最大请求数量(下图中是64),第二个maxRequestriansPerHost是判断请求的主机地址最大数量(下图中是5)

这里的runningAsyncCalls 和readyAsyncCalls 是用队列,因为队列的特性是双向的,更适合做插入和删除操作,满足需求,而且他们都是全局变量,存在内存中,用做执行判断

接着我们看执行方法,每个满足条件的AsyncCall 都会加到runningAsyncCalls 中

然后执行executorService().execute(call);

不满足(即超过请求数量,多余的先暂存)的放到readyAsyncCalls 中暂时存起来(后面会重新再获取执行)

这里的executorService实际上是个地址池在执行

Part2.

接着我们看看执行的 AsyncCall 是什么

调用了构造方法,执行了父类NamedRunnable的方法(redactedUrl().toString()地址请求的参数解析而已,不做解释)

父类NamedRunnable实现了Runnable说明是实现多线程

查看run方法(这里记录了线程名应该在其他地方有用到还没去查,这里暂时没用到,不做讲解)

执行了execute();

在AsyncCall 中找到execute方法,(getResponseWithInterceptorChain是远程调用获取返回信息的,具体关于请求http协议之类的这里不做讲解了,canceled在请求过程中会给予赋值)

执行完成后,finally中有个finished方法要执行

验证成功则执行 onResponse方法,失败则是onFailure方法,就是最早定义的方法体

进入finished方法,第一个if是移除执行过的方法,并判断是否有执行过

接着promoteCalls方法是对之前超过请求数量,暂存的请求重新再执行一遍,直到执行完毕

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值