事件循环 - 记录和分享
浏览器的进程模型
何为进程?
程序运⾏需要有它⾃⼰专属的内存空间,可以把这块内存空间简单的理解
为进程,每个应⽤⾄少有⼀个进程,进程之间相互独⽴,即使要通信,也需要双⽅
同意。
何为线程?
有了进程后,就可以运⾏程序的代码了。
运⾏代码的「⼈」称之为「线程」。⼀个进程⾄少有⼀个线程,所以在进程开启后会⾃动创建⼀个线程来运⾏ 代码,该线程称之为主线程。
如果程序需要同时执⾏多块代码,主线程就会启动更多的线程来执⾏代
码,所以⼀个进程中可以包含多个线程。
浏览器有哪些进程和线程?
浏览器是⼀个多进程多线程的应⽤程序
浏览器内部⼯作极其复杂。
为了避免相互影响,为了减少连环崩溃的⼏率,当启动浏览器后,它会⾃
动启动多个进程。

其中,最主要的进程有:
1.
浏览器进程
主要负责界⾯显示、⽤户交互、⼦进程管理等。浏览器进程内部会启动多个
线程处理不同的任务。
2.
⽹络进程
负责加载⽹络资源。⽹络进程内部会启动多个线程来处理不同的⽹络任务。
3.
渲染进程(本节课重点讲解的进程)
渲染进程启动后,会开启⼀个
渲染主线程,主线程负责执⾏ HTML、CSS、
JS 代码。
默认情况下,浏览器会为每个标签⻚开启⼀个新的渲染进程,以保证不同的
标签⻚之间不相互影响。
渲染主线程是如何⼯作的?
渲染主线程是浏览器中最繁忙的线程,需要它处理的任务包括但不限于:
- 解析 HTML
- 解析 CSS
- 计算样式
- 布局
- 处理图层
- 每秒把⻚⾯画 60 次
- 执⾏全局 JS 代码
- 执⾏事件处理函数
- 执⾏计时器的回调函数
......
要处理这么多的任务,主线程遇到了⼀个前所未有的难题:如何调度任
务?
⽐如:
我正在执⾏⼀个 JS 函数,执⾏到⼀半的时候⽤户点击了按钮,我该⽴即
去执⾏点击事件的处理函数吗?