Promise、try-catch-finally、async-await

前言: 以下示例代码, 基于node运行环境


Promise

  1. Promise是一个容器,保存异步代码的执行结果;
  2. 作用:解决异步回调地域(异步代码,层层嵌套);
  3. 缺陷:语法、编码上还是存在嵌套现象

文件路径:
在这里插入图片描述

const fs = require('fs')
function createPromise(name){
    return new Promise((resolve, reject) => {
        fs.readFile(`${__dirname}/${name}.txt`,'UTF-8', (error, data)=>{
            if(data){
                resolve(data)
            }else{
                reject(error)
            }
        })
    })
}
createPromise("a").then(data=>{
    console.log(data)
    return createPromise("b")
}).then(data=>{
    console.log(data)
    return createPromise("c")
}).then(data=>{
    console.log(data)
    return createPromise("d")
}).then(data=>{
    console.log(data)
}).catch(error=>{
    console.log(error)
})

执行结果:
在这里插入图片描述




try-catch-finally

  • 作用: 让开发者的代码更加健壮

  • 注意: catch 和 finally 语句都是可选的,但必须至少使用一个。


语法:

try {
    tryCode - 尝试执行代码块
}
catch(err) {
    catchCode - 捕获错误的代码块
}
finally {
    finallyCode - 无论 try / catch 结果如何都会执行的代码块
}




async-await

  1. async本身不起作用,仅仅是函数的修饰符, 但是只有用了async的函数, 才能在函数体中使用await来执行promise;
  2. await的函数的返回值就是promise的then结果
    let res = await promise实例
    

注意

  1. async-await也是解决回调地域的,比promise更强大,代替promise;
  2. await的异常,需要借助try-catch来捕捉

const fs = require('fs')
function createPromise (name) {
  return new Promise((resolve, reject) => {
    fs.readFile(`${__dirname}/${name}.txt`, 'UTF8', (error, data) => {
      if (data) {
        resolve(data)
      } else {
        reject(error)
      }
    })
  })
}
async function readFile () {
  try {
    let res1 = await createPromise('a')
    console.log(res1)

    let res2 = await createPromise('b')
    console.log(res2)

    let res3 = await createPromise('c')
    console.log(res3)
  } catch (error) {
      console.log(error)
  }
}
readFile()
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用所以可以说,async是Promise的一种语法糖,它简化了使用Promise的过程。 引用在给定的例子中,将async函数a()赋值给变量b,通过await关键字等待a()函数的返回结果,并将结果赋值给b。 引用在给定的例子中,readFile函数使用了async和await来等待createPromise函数返回的结果,并使用try-catch来处理可能出现的错误。 关于async await finally的问题,async函数中没有finally关键字,finally关键字是用于在try-catch结构中无论是否发生异常都会执行的代码块。在async函数中,可以使用try-catch来处理异常,但是没有类似finally的关键字来执行一段无论如何都会执行的代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Promise、async/await的用法](https://blog.csdn.net/liya_nan/article/details/80834101)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Promisetry-catch-finallyasync-await](https://blog.csdn.net/weixin_46873254/article/details/119457437)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值