EventLoop

JavaScript是单线程的语言

             JavaScript是一门单线程的编程语言。也就是说,同一时间只能做一件事情;

 

 

 单线程执行任务队列的问题:

  如果前一个任务非常耗时,则后续任务就不得不一直等待,从而导致程序假死的问题

同步任务和异步任务

  为了防止某个耗时任务导致程序假死的问题,JavaScript把待执行的任务分为了两类:

  1. 同步任务(synchronous)
    • 又叫做非耗时任务,指的是在主线程上排队执行的那些任务
    • 只有前一个任务执行完毕,才能执行后一个任务
  2. 异步任务(asynchronous)
    • 又叫做耗时任务,异步任务有JavaScript委托给宿主环境进行执行的
    • 当异步任务执行完成后,会通知JavaScript主线程执行异步任务的回调函数

同步任务和异步任务的执行过程

 

 

总结EventLoop的基本概念

    JavaScript主线程从“任务队列”中读取异步任务的回调函数,放在执行栈中依次执行。这个过程是循环不断的,所以整个得这种运行机制又称为EventLoop(事件循环)

例如:

import thenFs from 'then-fs'
console.log(1);
thenFs.readFile('./text/1.txt', 'utf8').then( res => {
    console.log(2);
})
setTimeout(v => {
    console.log(3);
},0)
console.log(4);

 正确的输出结果:

 

 其中:

  • 1 和 4 属于同步任务,会根据代码的先后顺序依次被执行;
  • 2 和 3 属于异步任务。他们的回调函数会被加入到任务队列中,等待主线程空闲时根据事件的循环机制进行再执行

 

posted @ 2022-05-28 17:56  perfect*  阅读(20)  评论(0编辑  收藏  举报
$(function() { $('#cnblogs_post_body img').each(function() { let imgSrc = $(this).attr('src'); let year = parseInt(imgSrc.substr(imgSrc.indexOf('g')+1,4)); if(year >= 2022){ imgSrc += `?watermark/2/text/amlndWl5YW4=/font/5a6L5L2T/fontsize/15/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast`; $(this).attr('src', imgSrc) } }) })