javascript中async/await机制及其中的promise

async/await本质上是利用这两个关键字,将异步执行代码,写成串行的样式,方便人阅读,这和android系统中的协程机制有点像,当然javascript环境中,不用过多的考虑进程、生命期和执行范围问题。

async关键词告诉计算机,这个函数是异步函数,调用它的主函数,不要等它,继续往下执行。而本函数会另启一个线程,按顺序执行函数内的代码。

await关键词告诉主函数,要等待跟着的函数执行完后才能往下执行,也就是变成了串行阻塞式运行,也就是即使await关键词后面跟的是异步函数,也会变成普通的同步函数。

那么什么是异步函数呢,最早的异步函数使用回调的方式,即把回调函数的地址传给异步函数,当异步函数执行完调用回调函数。但写起来层层叠叠很难看。后来发明了promise对象方式,即如果执行异步函数,就会在主线程返回一个promise对象,由promise对象通过then、catch、all、final等方法加载异步函数的善后处理程序。也就是全面通过promise对象管理异步函数。但写起来,还是一串一串,层层叠叠,这时就通过引入async/await关键词来封装和操作promise对象。

async关键词标注一个函数,就自动为该函数构造promise对象,函数中return的值就是promise的正常值resolve函数返回的值,throw出的异常就是reject函数返回的值。

await关键词引入的函数调用,就是告诉系统要等待该函数return出的值,当然,你也可以继续用promise对象的catch来捕获异常。

通过这样的调整,就可以形成这样的风格:把可能需要异步执行的代码块都封装在一个async标注的函数中,同时你也可以随时通过await函数将异步函数强制变回同步函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值