20230515学习笔记——js中的同步任务与异步任务,宏任务与微任务

Posted isDaHua

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了20230515学习笔记——js中的同步任务与异步任务,宏任务与微任务相关的知识,希望对你有一定的参考价值。

2023-05-15

(1)js中的同步任务与异步任务

①同步任务是指:不耗时的任务,就是执行很快,

②异步任务是指:耗时的任务,它里面有一个机制是EventLoop(事件循环),即值耗时任务会被js分配到宿主环境中进行执行,执行后的结果放到一个“消息队列”中,当js将同步任务执行完毕后,才会调用异步环境。在消息队列中的存放顺序的位置的规则是按照“谁(异步任务)先执行完,谁的运算结果先存放”,之后使用回调函数进行调用。

(2)有关EventLoop的经典面试题

 问题:请说明上述代码的执行顺序

结果:ADCB

理由:A与D时同步任务,readFile与setTimeout是异步任务。A,B先执行,C,D后执行,因为setTimeout中的0毫秒之后进行响应,它的返回结果需要的时间短,它先执行。readFile异步任务中读取文件需要时间,因此它最后执行。所以执行的结果是ADCB。

(3)宏任务与微任务

①宏任务与微任务都是异步任务

②宏观任务与微观任务的划分如下:

 

Js执行机制,同步任务异步任务

Js中是一个单线程的,但是分同步和异步,同步是依次执行的,如:洗衣服、做饭、烧水,按个按顺序执行;而异步任务,如:洗衣服的时候烧水,做饭;这就是同步与异步的区别。

异步的任务有:ajax的回调函数

        DOM事件的回调函数

        setTimeout、setInterval定时器的回调函数

笼统的可以说回调函数就是一个异步任务(不知道正不正确,待以后深入学习再回来看);

Js的执行同步异步任务的机制如图:

 

 

先看看用最简单的setTimeout异步任务吧:

 

 

 

 

其他回调函数都是这个道理。

点击了,给异步处理,然后函数结果进任务栈,主栈把里面的任务都拿出来执行。

以上是关于20230515学习笔记——js中的同步任务与异步任务,宏任务与微任务的主要内容,如果未能解决你的问题,请参考以下文章

Js执行机制,同步任务异步任务

JavaScript中的同步与异步

js的事件循环机制:同步与异步任务(setTimeout,setInterval)宏任务,微任务(Promise,process.nextTick)

js事件循环运行机制

js事件循环运行机制

Review——JS的异步与同步