javascript 的 promise 和 python future的一些思考

本文探讨了JavaScript中的Promise和Python中的Future的设计初衷、实现方式及使用场景。Promise主要解决回调地狱,提供异步调度,而Future旨在提供并发高级控制,如并发数控制和任务终止。在实现上,Promise依赖function提交任务,支持链式调用,而Future通过workitem在executor执行。使用上,Promise支持双向回调,Future不支持链式调用。两者都在各自的语言环境下,针对异步和并发提供了不同的解决方案。

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

从设计初衷来看

  1. promise 的设计初衷是:
    • 避免回调地狱(通过promise对象占位和then方法链式调用)
    • 异步调度(多个异步Task的线性化,也是通过then和resolve过程来实现的)
  2. future 的实际初衷是:
    • 提供并发的高级控制抽象
      • 通过semaphore 锁和executor实现并发数控制
      • 通过add_done_callback 提供了异步回调的接口
      • 通过cancle 提供了终止任务的接口

简而言之,prromise为的是异步,而future为的是并发。promise使得异步的代码更容易被理解和组织,而future使得并发的任务能更优雅的被管理。

从实现上看

  1. promise 的初始化需要提供一个function,在 new操作的时候就被提交到了js的任务队列里;然后通过then方法来组织不同的异步之间的关系
  2. future 的初始化是不需要一个function的,而只是提供了一个占位符对象,后面通过workitem对象来建立真正的并发任务,并且workitem需要submit到executor才会真的被执行

从使用上

  1. promise 因为专注异步所以支持了链式调用。而且是双向流的回调(onFulfilled, onRejected)
  2. future不支持链式调用, 也只是针对self的回调

其它

  1. javascript 语言本身支持了异步,比如通过setTimeout就可以将方法延后执行,其它io的函数也都是支持异步的,所以回调语法的反人类成为了痛点。
  2. python 本身并没有提供事件循环和任务队列,其异步是通过并发来做的,比如多进程、多线程、协程,所以并发任务的舒适管理成为了痛点。future使得程序员能很大程度绕开各种锁的使用
  3. 由于“世界上本来没有并发,异步用多了也就有了并发”,所以promise里也提供了和future一样的并发控制方法。
    • promise里的all race
    • python里的wait
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值