Review——JS的异步与同步

Posted 执白

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Review——JS的异步与同步相关的知识,希望对你有一定的参考价值。

一、概念

同步(synchronous):指在js的主线程上,所有任务被依次执行;

异步(asynchronous):指任务不进入主线程,进入任务队列(task);当“任务队列”通知主线程,异步任务才进入主线程执行。

二、异步的机制

  • 同步任务都在主线程上执行,形成一个“任务栈”;
  • 异步任务在“任务队列”中放置一个事件;
  • 主线程的“任务栈”执行完毕后,“任务队列”里的任务被唤醒,从而进入主线程执行;
  • 主线程不断重复上面三步。

任务队列里的事件主要指IO设备或用户行为触发的事件。

三、异步函数

  • setTimeout
  • setInterval
  • Promise

    三个状态:Pending,Fulfilled,Rejected。

    核心方法:resolve/then/reject/catch/all/race

  • async await

四、promise和async/await的区别

Promise

const makeRequest = () =>
  getJSON()
    .then(data => {
      console.log(data)
      return "done"
    })

makeRequest()

Async/Await

const makeRequest = async () => {
  console.log(await getJSON())
  return "done"
}

makeRequest()

综上,Async更简洁。

以上是关于Review——JS的异步与同步的主要内容,如果未能解决你的问题,请参考以下文章

Mocha.js 101同步异步与 Promise

Node.js 同步与异步编程

JS中同步与异步

JavaScript中的同步与异步

.Ajax(async异步与sync同步)

ajax同步与异步的区别