JS基础--任务队列和事件循环


任务队列

任务指的就是js代码中的运行的代码。
JS中的所有任务分两种:同步任务和异步任务
同步任务指的是: 主线程上的任务排队执行
异步任务指的是: 不进入主线程,而是进入一个"任务队列"的任务,当主线程中的任务执行完,才会从任务队列中取出异步任务放入主线程执行
异步任务又可分为:异步宏任务和异步微任务。
异步宏任务比如:定时器等。异步微任务:Promise等。官方规定的;

实现异步模式的方法有很多,比较常用的有:
(1)延迟类:setTimeout、setInterval、requestAnimationFrame、setImmediate。
(2)监听事件实现的类型:监听new Image加载状态、监听script加载状态、监听iframe加载状态、Message。
(3)带有异步功能类型 Promise、ajax等等。

案例

        setTimeout(()=>{              //setTimeout是添加了一个异步宏任务 等同步任务和异步微任务执行完后执行
            console.log(11111)     
        },1000)
       let p=new Promise((n1,n2)=>{
           n1(22222)    
       })
       p.then((n1)=>{       //Promise的then方法是添加一个异步微任务,等本轮同步任务执行后执行
            console.log(n1)
       })
       console.log(33333)  //同步任务,最先执行 打印33333

在这里插入图片描述

事件循环

当javascript代码执行的时候会将不同的变量存于内存中的不同位置:堆(heap)和栈(stack)中来加以区分。其中,堆里存放着一些对象。而栈中则存放着一些基础类型变量以及对象的指针。

当我们调用一个方法的时候,js会生成一个与这个方法对应的执行环境,又叫执行上下文。而当一系列方法被依次调用的时候,因为js是单线程的,同一时间只能执行一个方法,于是这些方法被排队在一个单独的地方。这个地方被称为执行栈

js引擎遇到一个异步事件后并不会一直等待其返回结果,而是会将这个事件挂起,继续执行执行栈中的其他任务。
当这个异步事件返回结果后,js会将这个事件加入与当前执行栈不同的另一个队列,我们称之为事件队列(任务队列)

被放入事件队列不会立刻执行其回调,而是等待当前执行栈中的所有任务都执行完毕, 主线程处于闲置状态时,主线程会去查找事件队列是否有任务。
如果有,那么主线程会从中取出排在第一位的事件,并把这个事件对应的回调放入执行栈中,然后执行其中的同步代码…,如此反复,这样就形成了一个无限的循环。这就是这个过程被称为“事件循环”的原因。
执行栈则是一个类似于函数调用栈的运行容器。当执行栈为空时,JS 引擎便检查事件队列,如果不为空的话,事件队列便将第一个任务压入执行栈中运行。
这种不停的检查事件队列的操作,成为事件循环
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

H5_ljy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值