promise + yield = 异步流程控制

promise + yield = 异步流程控制

异步计算已经成为前后端不阻塞主线程的不二选择,无论是增加性能或是提升用户体验,anyway,这年头谁不用两下并发呢?

既然说到异步那就不得不提 promise 了,这个新的语法糖虽然建立在 callback 之上,但也好歹止住了之前愚民们疯狂跳进回调地狱的恶魔崇拜似的势头。ES的功劳一件。 或许你说你之前用过 co ?来做异步流程控制。那么作为一个程序好奇猫,你一定剖析过 co 的源码吧,很好奇它怎么使用 yield 来控制 promise 的同步。 在本文中我将以 5个语句解析之。。。 没错,就是5个语句。

sheepOut = new Promise( function(resolve) { 
    waitForTime(500); 
    resolve( log( "Eat grass" ) ) })

eatGrass = function *() {
    var ret = yield sheepOut()
    sheepBack()
}

step = eatGrass() // yield 就像坏掉的钟,拨一下,走一下。
not_done_promise = step.next() //sheepOut被异步调用了,返回一个还未结束的promise
not_done_promise.then( step.next() ) // 这句话是关键也就是说 sheepOut 未结束
//step 就一直卡在 yield, 直到 sheepOut 执行完毕,then 调用 next 进入 sheepBack.

所以整个流程是这样的
sheepOut(异步) -> yield(阻塞) -> sheepOut.then(调用next结束yield阻塞) -> sheepBack

怎么样?现在你能理解异步流程控制的技巧了没?说穿了就是靠 promise 的 then 回调 generator 的 next 来解除流程的阻塞。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值