我是靠谱客的博主 淡淡长颈鹿,最近开发中收集的这篇文章主要介绍浏览器渲染进程进程和线程浏览器渲染进程JS 引擎线程与 GUI 渲染线程互斥运行机制React Concurrent 模式背景参考,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

进程和线程

进程是 CPU 资源分配的最小单位,线程是 CPU 调度的最小单位。

进程之间相互独立,一个进程的内存空间是共享的,每个线程都可以使用这些共享内存,一个进程可以存在一个或多个线程,也就是单线程或多线程。

多进程形式,允许多个任务同时运行;多线程形式,允许单个任务分成不同的部分运行。

浏览器渲染进程

浏览器是多进程的,其中包括浏览器主进程、第三方插件进程、GPU 进程、浏览器渲染进程。

浏览器渲染进程是浏览器内核,主要负责 HTML、CSS、JS 等文件的解析和执行。

浏览器渲染进程是多线程的,包含的线程主要有 GUI 渲染线程、JS 引擎线程、事件处理线程、定时器触发线程、HTTP 请求线程。

其中,GUI 渲染线程、JS 引擎线程、事件处理线程是常驻线程。

GUI 渲染线程

GUI 渲染线程的执行过程如下:

在这里插入图片描述

  1. 根据 HTML 代码生成 DOM 树,同时浏览器主进程负责下载 CSS 文件
  2. CSS文件下载完成,根据 CSS 代码生成 CSSOM
  3. 将 DOM 树和 CSSOM 整合为渲染树
  4. 计算元素的尺寸、位置等几何信息,布局渲染树(回流)
  5. 绘制页面的像素信息(重绘)
  6. 显示出页面

JS 引擎线程

JS 引擎线程是主线程,一个浏览器渲染进程只有一个 JS 引擎线程在运行,即所谓“JS 是单线程的”。JS 引擎线程负责解析 JS 脚本运行代码,在运行代码时会生成一个 执行栈

事件处理线程

事件处理线程管理着 任务队列,异步任务的回调函数会放在其中,等待 执行栈 中的任务执行完毕后,读取其中任务执行。

定时器触发线程

定时器 setTimeoutsetInterval 通过这个单独的线程计时,计时完毕后添加到 任务队列 中,等待 JS 引擎线程空闲时执行。

HTTP 请求线程

HTTP 请求连接时,会执行这个线程。状态变更时,如果有回调函数,这个回调函数会添加到 任务队列 中,等待 JS 引擎线程执行。

JS 引擎线程与 GUI 渲染线程互斥

一个栗子:
以下代码中,DOM 的操作是同步进行的,而 console.log() 的 “div: ” 部分先打印出来,后面的 div 元素在阻塞后才有值,好像表现为异步。

const body = document.querySelector('body');
const div = document.createElement('div');
console.log('div: ', div);
body.appendChild(div);
for (let i = 0; i < 1000000000; i++);

其实是因为 JS 引擎线程与 GUI 渲染线程互斥,线程之间的“同步”使得 DOM 操作产生了“异步”的效果。

GUI 渲染线程与 JS 引擎线程是互斥的,当 JS 引擎执行时 GUI 线程会被挂起,GUI 更新会被保存在一个队列中等到 JS 引擎空闲时立即被执行,GUI 线程执行时同理。

运行机制

运行机制是:宏任务 -> 微任务 -> 调度 GUI 渲染线程 -> 宏任务……

主流浏览器刷新频率为60Hz,即每(1000ms / 60Hz)16.6ms浏览器刷新一次。如果一次事件循环的用时超出了16.6ms,那么在这次刷新就没有时间进行样式布局和样式绘制,就会造成页面掉帧卡顿。

React Concurrent 模式背景

React 为了实现“快速响应”,主要在“CPU 瓶颈”和“IO 瓶颈”两个场景下受到制约。其中 CPU 的瓶颈,就是当遇到大计算量的操作或者设备性能不足时,JS 脚本执行时间过长,页面掉帧,造成卡顿。

而 Concurrent 模式就是为了解决 CPU 瓶颈,通过将长任务分拆到每一帧中而不是一直执行,并在每一帧都留出时间渲染 UI,实现时间切片,将同步的更新变为可中断的异步更新。

参考

JS中操作DOM是"同步"还是"异步"?
彻底搞清楚浏览器渲染过程
从浏览器多进程到JS单线程,JS运行机制最全面的一次梳理
React技术揭秘

最后

以上就是淡淡长颈鹿为你收集整理的浏览器渲染进程进程和线程浏览器渲染进程JS 引擎线程与 GUI 渲染线程互斥运行机制React Concurrent 模式背景参考的全部内容,希望文章能够帮你解决浏览器渲染进程进程和线程浏览器渲染进程JS 引擎线程与 GUI 渲染线程互斥运行机制React Concurrent 模式背景参考所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(66)

评论列表共有 0 条评论

立即
投稿
返回
顶部