前端秘法进阶篇之事件循环

目录

一.浏览器的进程模型

1.进程

2.线程

二.浏览器的进程和线程

1. 浏览器进程

2. 网络进程

3. 渲染进程

三.渲染主线程

四.异步

五.优先级

1. 延时队列:

2.交互队列:

3.微队列:

六.JS 的事件循环

附加:JS 中的计时器能做到精确计时吗


一.浏览器的进程模型

1.进程

程序运行需要有专属的内存空间,可以把这块内存空间简单的理解为进程

在这里我们把不同的颜色看做不同的程序运行时所需要的内存空间,每个应用至少有一个进程,进程之间相互独立,如果要联系,需要双方同意.

2.线程

有了进程之后就可以开始运行代码,那么谁来运行代码呢?其实就是线程

一个进程至少有一个线程(换句话说,就是给你分配内存空间,你就要去利用)

进程开启后会自动创建一个线程运行代码,该线程称之为主线程.

如果程序需要同时执行多个代码,主线程就会启动更多的线程来执行代码,所以一个进程中可以包含多个线程

二.浏览器的进程和线程

浏览器是一个多进程多线程的应用程序

浏览器内部工作极其复杂。

为了避免相互影响,为了减少连环崩溃的几率,当启动浏览器后,它会自动启动多个进程。

可以在浏览器的任务管理器中查看当前的所有进程

其中,最主要的进程有:

1. 浏览器进程

主要负责界面显示、用户交互、子进程管理等。浏览器进程内部会启动多个线程处理不同的任务。

2. 网络进程

负责加载网络资源。网络进程内部会启动多个线程来处理不同的网络任务。

3. 渲染进程

 渲染进程启动后,会开启一个**渲染主线程**,主线程负责执行 HTML、CSS、JS 代码。

 默认情况下,浏览器会为每个标签页开启一个新的渲染进程,以保证不同的标签页之间不相互影     响。

三.渲染主线程

渲染主线程是浏览器中最繁忙的线程,需要它处理的任务包括但不限于:

- 解析 HTML/解析

评论 42
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一枕眠秋雨>o<

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

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

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

打赏作者

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

抵扣说明:

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

余额充值