首页 > 其他分享 >异步函数 async function

异步函数 async function

时间:2024-10-21 17:13:28浏览次数:8  
标签:function 异步 console 函数 Promise async log

◼ async关键字用于声明一个异步函数:
  async是asynchronous单词的缩写,异步、非同步;
  sync是synchronous单词的缩写,同步、同时;
◼ async异步函数可以有很多中写法
async function foo(){}
const foo1 = async function(){}
const foo2 = async ()=>{}
class Person{
  async foo(){}
}

异步函数的执行流程

◼ 异步函数的内部代码执行过程和普通的函数是一致的,默认情况下也是会被同步执行。
◼ 异步函数有返回值时,和普通函数会有区别:
  情况一:异步函数也可以有返回值,但是异步函数的返回值相当于被包裹到Promise.resolve中;
  情况二:如果我们的异步函数的返回值是Promise,状态由会由Promise决定;
  情况三:如果我们的异步函数的返回值是一个对象并且实现了thenable,那么会由对象的then方法来决定;
◼ 如果我们在async中抛出了异常,那么程序它并不会像普通函数一样报错,而是会作为Promise的reject来传递;

异步函数的返回值

 //1.返回值区别
  // 普通函数
    function foo1(){

    }
    foo1()//默认返回undefined
    //2.异步函数
    async function foo2() {
      //1.返回一个普通的值
      // return 321 // Promise.resolve(321)
      // 2.返回一个Promise
      // return new Promise((reslove,reject)=>{
      //   setTimeout(()=>{
      //     reslove("aaa")
      //   },3000)
      // })
      //3.返回一个thenable对象
      return{
        then:function(resolve,reject){
          setTimeout(()=>{
            resolve("bbb")
          },3000)
        }
      }
    }
    foo2()//异步函数默认返回Promise
    foo2().then(res=>{
      console.log(res)//02-异步函数-异步函数返回值.html:22 321
    })

异步函数的reject或者出现异常

  // 什么情况下结果时rejected
async function foo() {
  console.log("111111111111")
  console.log("222222222222")
  // 如果异步函数有抛出异常(产生错误),这个异常不会被立即被浏览器处理
  // 进行如下处理:Promise.reject(error)
  // "abc".filter()
  throw new Error("hdc:出错了")
  console.log("333333333333")

  return 123
}
//promise:1.pending(待定) 2.fullfiled(成功) 3.rejected(失败)
foo().then(res=>{
  console.log(res)//123
}).catch(err=>{
  console.log(err)
})

await关键字

◼ async函数另外一个特殊之处就是可以在它内部使用await关键字,而普通函数中是不可以的。
◼ await关键字有什么特点呢?
    通常使用await是后面会跟上一个表达式,这个表达式会返回一个Promise;
    那么await会等到Promise的状态变成fulfilled状态,之后继续执行异步函数;
◼ 如果await后面是一个普通的值,那么会直接返回这个值;
◼ 如果await后面是一个thenable的对象,那么会根据对象的then方法调用来决定后续的值;
◼ 如果await后面的表达式,返回的Promise是reject的状态,那么会将这个reject结果直接作为函数的Promise的reject值;
function bar(){
  console.log("bar() 函数执行")
  return new Promise((resolve,reject)=>{
    setTimeout(()=>{
      resolve(123)
    },100000)
  })
}
//await 关键字:必须在异步函数中使用
  async function foo(){
    console.log("------------")
    // await 是等待Promise有结果之后才会执行后续代码
    const res = await bar()
    console.log("await后续代码",res)
    console.log("++++++++++++")
  }
  foo()

await 和async结合使用

    //1.定义一些其他的异步函数
    function hdc(url){
      return new Promise((resolve,rejdect)=>{
        setTimeout(()=>{
          resolve(url)
        },2000)
      })
    }
   async function test(){
      console.log("test 函数")
      return "test"
    }
    async function bar() {
      console.log("bar 函数")
      return new Promise((resolve)=>{
        setTimeout(()=>{
          resolve("bar")
        },2000)
      })
    }
    async function demo() {
      console.log("demo函数")
      return{
        then:function(resolve){
          resolve("demo")
        }
      }
    }
    //2.调用的入口async函数
    async function foo() {
      const res1 = await hdc("hdc")
      console.log("res1",res1)
      // 异步函数本来就返回Promise
      const res2 = await test()
      console.log("res2",res2)
      const res3 = await bar()
      console.log("res3",res3)
      const res4 = await demo()
      console.log("res4",res4)
    }
    foo()

标签:function,异步,console,函数,Promise,async,log
From: https://www.cnblogs.com/hdc-web/p/18489858

相关文章

  • [Javascript] Write memoize function
    classMemoizeMap{constructor(){this._map=newMap();this._weakMap=newWeakMap();}_isObject(v){returntypeofv==="object"&&v!==null;}set(key,value){if(this._isObject(key)){this._......
  • 回调方式和异步方式的优缺点
    IC卡读卡器web插件目前提供2种接口调用方式,一种直接调用,使用回调函数返回数据。另外一种采用异步await调用,直接返回数据。这两种方式都有自己的优势,回调方式适合自动寻卡或者自动读取IC卡数据,刷卡自动就能返回数据,web页面只需要等待数据即可。异步调用方式更适合一系列的......
  • java线程异步方法
    异步的八种实现方式:线程异步Thread/RunnableFuture+Callable异步框架CompletableFutureSpring注解@AsyncSpringApplicationEvent事件第三方异步框架,比如Hutool的ThreadUtilGuava异步消息队列1、线程异步publicclassThreadTestimplementsRunnable{......
  • STA模型、同步上下文和多线程、异步调度
    写过任何桌面应用,尤其是WinForm的朋友们应该见过,Main函数上放置了一个[STAThread]的Attribute。而且几乎所有的桌面应用框架,都是由同一个UI线程来执行渲染操作的,这表现为从其他线程修改控件的值就会抛异常:awaitTask.Run(()=>control.Content="");//throwsexception大家......
  • 异步MQ:后发先至
    目录一、消息排序与识别1、消息添加时间戳或序列号2、识别重复消息二、状态管理与补偿机制1、维护处理状态2、建立补偿机制三、监控与告警1、实时监控消息处理顺序2、告警与通知在异步处理过程中,当出现消息“后发先至”的情况时,消费者可以采取以下措施来处理:一、......
  • qwen2.5 ollama推理;openai function call调用中文离线agents使用
    ollama部署qwen2.5:3b0.3.11版本agents使用https://qwen.readthedocs.io/en/latest/framework/function_call.htmlfromopenaiimportOpenAIimportjsondefsend_messages(messages):response=client.chat.completions.create(model="qwen2.5:3b......
  • C#异步计数器的使用
    1、CancellationTokenSourcecancellationToken=newCancellationTokenSource();publicvoidInitData(){cancellationToken.Token.Register(()=>{Name="被取消了";});intcount=0;Task.Run(()=>{whi......
  • script 标签中 defer 和 async 的区别
    https://www.cnblogs.com/huangtq/p/18422775 在 <script> 标签中,defer 和 async 是两个用于控制JavaScript脚本加载和执行行为的属性。它们的主要区别在于加载顺序和执行时机。具体如下:1. defer 属性加载方式:使用 defer 的脚本在HTML解析的同时异步加载。......
  • sql-function
    在SQLite中,除了LENGTH函数,还有许多其他内置函数,分类如下:字符串函数UPPER(string):将字符串转换为大写。LOWER(string):将字符串转换为小写。SUBSTR(string,start,length):返回从指定位置开始的子字符串。TRIM(string):删除字符串两端的空白字符。REPLACE(string,old......
  • dockerfile中nuget源加载失败Retrying 'FindPackagesByIdAsync' for source 'xxx'
    问题描述:最近jenkins打包总是提示微软源加载不到Retrying'FindPackagesByIdAsync'forsource'https://api.nuget.org/v3-flatcontainer/microsoft.extensions.primitives/index.json'.Anerroroccurredwhilesendingtherequest.解决方案:dockerfile中添加国内源,改用华......