【工作实践篇】等待轮询结果后再发请求

为啥会有这篇 ?

  • 一些同学说 想看 工作中常用的一些操作分享, 它来了

在一些场景下我们需要去重复请求接口 数据

经典场景

1. 多人点单 选择商品后需要 重复拉取 order 接口 获取最新订单信息
2. 审批状态比如多个人都在审批一个单 当一个人审批了 更改了审批状态 需要通知其他人 
...... 

实现

  • 其实 实现轮询 非常 简单* 先给一个 最简单轮询版本```
    this.timer = setInterval(async () => {await this.getList()
    },2000)

// 然后在适当时机清楚(比如 离开页面)
clearInterval(this.timer)


* 看起来 非常 简单 问题是 setInterval 并不会自我清除

`更优雅的方式`
--------

* 这样的好处是 setTimeout 会在每次结束 清除自己 且在 恰当时机 执行 time = 0 , 此处需要了解一下 宏认为/微任务* 但 无法解决 等待轮询结果后再发请求```
this.timer = setInterval(() => {
setTimeout(()=> {
...
},0)
},2000)

// 然后在适当时机清楚(比如 离开页面)
clearInterval(this.timer) 
  • (条件 网络 low 3G模拟接口慢的情况 轮询1s 测试快速发请求情况)

这样实现后 大概是 这样

  • 我们可以 很明确的发现 前一条 没有请求结束 后一条请求 又跟上了* 会出现这样的情况

  • 出现多个地方 接口 报错 ! 非常 不 nice

再优雅一波

const STATUS_INTERVAL = 2 * 1000const queryOrderStatus = () => {this.timer = setTimeout(async () => {await xxxxxqueryOrderStatus();}, STATUS_INTERVAL);};queryOrderStatus();// 然后在适当时机清楚(比如 离开页面)
clearInterval(this.timer) 
  • 实现效果
  • 有没有想过为啥 ? 递归 和 await 功效 good* 如果多个 请求 可叠加 / Promise.all(…)* 更多 技术实践 正在袭来 …

最后

整理了一套《前端大厂面试宝典》,包含了HTML、CSS、JavaScript、HTTP、TCP协议、浏览器、VUE、React、数据结构和算法,一共201道面试题,并对每个问题作出了回答和解析。

有需要的小伙伴,可以点击文末卡片领取这份文档,无偿分享

部分文档展示:



文章篇幅有限,后面的内容就不一一展示了

有需要的小伙伴,可以点下方卡片免费领取

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于 HttpAsyncClient 轮询结果的问题,可以通过使用 FutureCallback 来实现异步请求的结果轮询。 FutureCallback 是一个回调接口,定义了请求成功和请求失败时的处理方法。在送异步请求时,可以将一个 FutureCallback 对象作为参数传递给 HttpAsyncClient.execute() 方法,当请求完成时,会回调 FutureCallback 对象的方法,以便处理请求结果。 以下是一个简单的示例代码,演示了如何使用 FutureCallback 来实现异步请求的结果轮询: ```java CloseableHttpAsyncClient client = HttpAsyncClients.createDefault(); client.start(); HttpGet request = new HttpGet("http://www.example.com"); FutureCallback<HttpResponse> callback = new FutureCallback<HttpResponse>() { @Override public void completed(HttpResponse response) { // 处理请求成功的响应结果 } @Override public void failed(Exception ex) { // 处理请求失败的情况 } @Override public void cancelled() { // 处理请求取消的情况 } }; Future<HttpResponse> future = client.execute(request, callback); while (!future.isDone()) { // 轮询请求结果 } client.close(); ``` 在上述示例代码中,首先创建了一个 CloseableHttpAsyncClient 实例,并启动该客户端。然后创建一个 HttpGet 请求实例,并使用 execute() 方法送异步请求,将一个 FutureCallback 对象作为参数传递给该方法。 接下来,在 while 循环中,使用 future.isDone() 方法不断轮询请求是否完成。当请求完成时,可以在 FutureCallback 中处理请求结果,如在 completed() 方法中处理请求成功的响应结果。 最后,关闭 HttpAsyncClient 实例以释放资源。 希望我的回答能够解决您的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值