js三座大山之异步-async/await

1、async定义的函数,不写return,调用后返回的是一个promise

2、await后面的代码相当于异步回调。

3、await相当于then

4、await后面写值相当于外面包裹了一层Promise.resolve。

示例代码:

async function async1() {
    console.log(1)
} 
let p1 = async1()
console.log(2)
// console.log(p1)
//结论:1、async定义的函数,不写return,调用后返回的是一个promise

async function async2() {
    await async1()
    console.log(3)
}
let p2 = async2()
console.log(4)
//结论:2、await后面的代码相当于异步回调。

async function async3 () {
    console.log('async3')
    return Promise.resolve('async3 data')
}

    
!(async function(){
    let result = await async3()
    console.log("async3-result =>",result)
})()   //此为匿名函数,定义后调用



//结论:3、await相当于then

!(async function(){
    let result = await Promise.resolve(123)
    console.log("result1 =>",result)
})() 

//结论:4、await后面写值相当于外面包裹了一层Promise.resolve。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
异步函数是指可以在函数执行过程中进行其他操作,并且不会阻塞当前线程。Swift 5.5 中引入的 async/await 机制可以更加方便地编写异步代码async/await 是一种便捷的语法糖,可以使我们使用类似于同步代码的方式来编写异步代码。 在使用 async/await 时,我们需要将异步操作包装在一个异步函数内部,并使用 async 标记该函数。在这个函数内部,可以使用 await 关键字来等待一个异步操作的结果。使用 await 关键字来等待异步操作的结果时,该操作会在后台线程上执行,当前线程会暂时挂起,直到异步操作完成。 async/await 的运行机制是基于 Swift 的协程机制。在一个异步函数中,当遇到需要等待的异步操作时,函数会被暂停,并且当前的函数状态会被保存。然后,异步操作会在后台线程上执行,一旦完成,会将结果返回给原来的异步函数。然后异步函数会继续执行,直到遇到下一个需要等待的异步操作或者函数结束。 使用 async/await 可以使得异步代码更加易读和可维护。我们可以使用常见的流程控制语句如 if、for 和 try-catch 来编写异步代码,而不再需要使用回调函数或者 Promise 链式调用来处理异步操作。这种方式提供了更加直观和简洁的代码结构。 总结起来,async/await 是 Swift 中用于编写异步代码的一种便捷的语法糖。它基于协程机制,可以使得异步代码更加易读和可维护。通过 async/await,我们可以使用类似于同步代码的方式来编写异步代码,提高开发效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值