前端必会--浏览器的工作原理与实践

news2025/1/11 5:08:20

进程与线程

线程

线程分为单线程和多线程
线程是不能单独存在的,它是由进程来启动和管理的。

进程

一个进程就是一个程序的运行实例。详细解释就是,启动一个程序的时候,操作系统会为该程序创建一块内存,用来存放代码、运行中的数据和一个执行任务的主线程,我们把这样的一个运行环境叫进程。

在这里插入图片描述
线程依附于进程,而进程中使用多线程并行处理能提升运算效率

进程和线程的关系有以下4个特点:
1.进程的任一线程崩溃,都会导致整个程序出错
2.线程之间共享进程的数据
3.当一个进程关闭后,系统会回收进程所占内存
4.进程之间的内容相互隔离
最初的浏览器都是单进程的,它们不稳定、不流畅且不安全,之后出现了 Chrome,创造性地引入了多进程架构,并解决了这些遗留问题。随后 Chrome 试图应用到更多业务场景,如移动设备、VR、视频等,为了支持这些场景,Chrome 的架构体系变得越来越复杂,这种架构的复杂性倒逼 Chrome 开发团队必须进行架构的重构,最终 Chrome 团队选择了面向服务架构(SOA)形式,原来的各种模块会被重构成独立的服务(Service),每个服务(Service)都可以在独立的进程中运行,访问服务(Service)必须使用定义好的接口,通过 IPC 来通信,从而构建一个更内聚、松耦合、易于维护和扩展的系统,这也是 Chrome 团队现阶段的一个主要任务。
在这里插入图片描述

TCP协议:如何保证页面文件能被完整送达浏览器?

连接过程包括了建立连接、传输数据和断开连接三个阶段

HTTP请求流程:为什么很多站点第二次打开速度会很快?

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

从输入URL到页面展示,这中间发生了什么?

在这里插入图片描述
1.DNS解析:浏览器首先检查缓存中是否有该URL对应的IP地址,如果没有,就要进行DNS解析。这个过程包括查找本地Hosts文件、查询本地DNS服务器,如果本地DNS服务器中也没有对应的IP地址,就会向根服务器查询,然后由根服务器指向下一级,直到找到对应的IP地址。
2.建立TCP连接:找到IP地址后,浏览器和服务器建立TCP连接,进行TCP三次握手。
3.发送HTTP请求:TCP连接建立后,浏览器就会向服务器发送HTTP请求,包括请求方法(GET、POST等)、请求路径、HTTP版本、请求头等信息。
4.服务器处理请求并返回HTTP报文:服务器接收到请求后,根据请求信息处理请求,然后返回一个HTTP响应。响应中包含响应状态码、响应头和响应体(即网页的HTML代码)。
5.浏览器解析HTML代码,并请求HTML代码中的资源:浏览器接收到服务器返回的HTML代码后,开始解析HTML,构建DOM树,然后解析CSS和JavaScript,构建CSSOM树,生成渲染树同时请求HTML中引用的资源,如图片、音视频、CSS、JavaScript文件等
6.浏览器对页面进行渲染:HTML、CSS和JavaScript文件加载完成后,浏览器会根据渲染树对页面进行渲染,展示给用户。
7.断开连接:如果HTTP协议版本为1.0,那么浏览器接收完服务器的响应后就会断开TCP连接。如果是HTTP1.1,那么浏览器会在一段时间内保持连接,以便再次请求该服务器时复用TCP连接。

用户发出 URL 请求到页面开始解析的这个过程,就叫做导航

  1. 用户输入
  2. URL 请求过程
    状态码处理
2xx (成功)200 OK:请求成功处理,返回的内容取决于请求的方法。
204 No Content:请求成功处理,但没有资源可以返回(通常在更新资源时使用)。
3xx (重定向)301 Moved Permanently:请求的资源已被永久性地转移到新的URL。
302 Found:请求的资源临时转移到了新的URL。
304 Not Modified:资源未更改(缓存)。
4xx (客户端错误)400 Bad Request:请求语法有误,服务器无法解析。
401 Unauthorized:请求需要用户认证或者认证失败。
403 Forbidden:服务器理解请求,但是拒绝执行(权限不足)。
404 Not Found:请求的资源在服务器上未找到。
5xx (服务器错误)500 Internal Server Error:服务器内部错误,无法完成请求。
502 Bad Gateway:作为网关或者代理的服务器,从上游服务器收到了无效的响应。
503 Service Unavailable:由于临时的服务器维护或者过载,服务器当前无法处理请求

响应类型处理 Content-Type
3. 准备渲染进程

文本类型:
text/plain:纯文本。
text/html:HTML 文档。
text/css:CSS 样式信息。
text/javascript:JavaScript 程序代码。
应用类型:
application/json:JSON 数据。
application/xml:XML 数据。
application/octet-stream:二进制流数据(如图片、视频、音频等)。
application/pdf:PDF文档。
application/zip:ZIP压缩文件。
图像类型:
image/jpeg:JPEG 图像。
image/png:PNG 图像。
image/gif:GIF 图像。
image/svg+xml:SVG 矢量图像。
image/webp:WebP 图像。
音频/视频类型:
audio/mpeg:MPEG 音频。
audio/ogg:OGG 音频或视频。
video/mp4:MP4 视频。
  1. 准备渲染进程
https://time.geekbang.org 
https://www.geekbang.org 
https://www.geekbang.org:8080

了解下什么是同一站点(same-site)。具体地讲,我们将“同一站点”定义为根域名(例如,geekbang.org)加上协议(例如,https:// 或者 http://) time、www属于子域名
如果从一个页面打开了另一个新页面,而新页面和当前页面属于同一站点的话,那么新页面会复用父页面的渲染进程
在这里插入图片描述

页面渲染流程

了解其相关流程能让你“看透”页面是如何工作的,有了这些知识,你可以解决一系列相关的问题,比如能熟练使用开发者工具,因为能够理解开发者工具里面大部分项目的含义,能优化页面卡顿问题,使用 JavaScript 优化动画流程,通过优化样式表来防止强制同步布局,等等。

构建 DOM 树

在这里插入图片描述
在这里插入图片描述
图中的 document 就是 DOM 结构,你可以看到,DOM 和 HTML 内容几乎是一样的,但是和 HTML 不同的是,DOM 是保存在内存中树状结构,可以通过 JavaScript 来查询或修改其内容。

样式计算在这里插入图片描述

在这里插入图片描述
样式来源(位于图中的区域 3 中)中查看样式的具体来源信息,看看是来源于样式文件,还是来源于 UserAgent 样式表。这里需要特别提下 UserAgent 样式,它是浏览器提供的一组默认样式,如果你不提供任何样式,默认使用的就是 UserAgent 样式。

重排、重绘、与合成

重排

从上图可以看出,如果你通过 JavaScript 或者 CSS 修改元素的几何位置属性,例如改变元素的宽度、高度等,那么浏览器会触发重新布局,解析之后的一系列子阶段,这个过程就叫重排。无疑,重排需要更新完整的渲染流水线,所以开销也是最大的。

重绘

从图中可以看出,如果修改了元素的背景颜色,那么布局阶段将不会被执行,因为并没有引起几何位置的变换,所以就直接进入了绘制阶段,然后执行之后的一系列子阶段,这个过程就叫重绘。相较于重排操作,重绘省去了布局和分层阶段,所以执行效率会比重排操作要高一些。

合成

那如果你更改一个既不要布局也不要绘制的属性,会发生什么变化呢?渲染引擎将跳过布局和绘制,只执行后续的合成操作,我们把这个过程叫做合成,在上图中,我们使用了 CSS 的 transform 来实现动画效果,这可以避开重排和重绘阶段,直接在非主线程上执行合成动画操作。这样的效率是最高的,因为是在非主线程上合成,并没有占用主线程的资源,另外也避开了布局和绘制两个子阶段,所以相对于重绘和重排,合成能大大提升绘制效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1861078.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

OpenAI扩大版图,收购Mac协作应用巨擘Multi

Multi,这款专为macOS用户打造的多人协作应用,凭借其卓越的低延迟实时协作功能,如共享光标、绘图和键盘控制,在业界享有盛誉。如今,OpenAI宣布成功收购Multi,以进一步扩大其技术生态。Multi公司将停止运营&a…

ppt忘记保存怎么恢复?

朋友们大家好,我是热爱分享电脑知识的资源伙伴~接下来,别忘了点赞、收藏并关注资源伙伴!如果你在使用PowerPoint时忘记保存演示文稿,突然关闭程序或电脑出现故障,不用太担心。 PowerPoint和大多数现代Office应用程序都…

将本地项目托管到Github或码云中

最按照打开页面的步骤,一步步生成公钥就: 按照提示完成三次回车,即可生成 ssh key 到C:\Users\登录用户名.ssh下找到文件d_rsa.pub ,打开就可以获取到public key 将id_rsa.pub文件中的内容全部复制到设置/SSH页面中: 单…

PWN练习---Stack_1

pwn123 题源:ctfshow–pwn123 知识点:逻辑漏洞引发的数组越界,导致任意地址写,覆盖返回地址。 主要源码 查看ida存在后面函数,可以劫持ctfshow函数的返回值到backdoor获得shell。 查看case 1代码发现并未对数组赋值的…

ThreadLocal 源码浅析

前言 多线程在访问同一个共享变量时很可能会出现并发问题,特别是在多线程对共享变量进行写入时,那么除了加锁还有其他方法避免并发问题吗?本文将详细讲解 ThreadLocal 的使用及其源码。 一、什么是 ThreadLocal? ThreadLocal 是 J…

Ubuntu下Linux最常见归档与解压命令tar的用法备忘

一、tar命令说明: tar是Linux中备份文件的可靠方法,用于打包、压缩与解压文件,可以工作于任何环境,使用权限是所有用户。 二、压缩与解压最常见的打包文档的格式: 三、常见两种压缩格式的说明: 文件名.tar.…

期权义务仓和权利仓有什么区别?怎么使用?

今天带你了解期权义务仓和权利仓有什么区别?怎么使用?与其他保险产品相比,期权提供更大的灵活性,投资者可以根据个人需求和市场状况选择不同类型和到期时间的期权合约,那么期权义务仓和权力仓是什么? 权利…

构建一个检索增强生成(RAG)应用程序

:::tips 此文档是LangChain官方教程的实践总结:https://python.langchain.com/v0.2/docs/tutorials/rag/实践前你需要准备:OPENAI_API_KEY Generator:根据检索到的信息和用户的查询生成自然语言的回答。LANGCHAIN_API_KEY 密切监控和评估您的…

加速度传感器采集时无效数据的产生及消除

1.现象 这是振动传感器的原始采样信号,它有一个明显的上升沿,这个上升沿,看时间轴标尺,大概持续了至少50ms,它是从哪里来的呢? 加速度传感器一般是由恒流源驱动的。而恒流源的原始电源输入是个经由电源模…

3dmax最小细分,最大细分,全局细分倍增怎么设置才合理

在3ds Max中进行高质量渲染时,细分(Subdivision)是一个至关重要的参数。细分的设置直接影响到渲染结果的细节程度和渲染时间。以下内容详细解释最小细分、最大细分和全局细分倍增的含义及作用,并解释在渲染设置时,怎样…

Llama3应用与RAG的实现

源码见文末 实现效果 1.Llama3安装 官网:https://ollama.com/download/linuxhttps://ollama.com/download/linux 首先,安装ollama, 安装后能够很好下载其模型

如何只用 ClickHouse SQL 实现 K-Means 聚类

本文字数:15474;估计阅读时间:39 分钟 审校:庄晓东(魏庄) 本文在公众号【ClickHouseInc】首发 Meetup活动 ClickHouse 上海首届 Meetup 讲师招募中,欢迎讲师在文末扫码报名! 介绍 最…

扫地机器人无故中止问题的TRIZ解决方案

在我们享受智能家居带来的便捷时,扫地机器人无疑是家中不可或缺的“小帮手”。然而,当这个小家伙突然“罢工”,不再听从我们的指令,甚至无故中止工作时,你是否也感到头疼不已?今天,深圳天行健企…

关于ip地址的网页无法访问navigator的gpu、媒体、蓝牙等设备的解决方法

在使用threejs的WebGPURenderer渲染器时,发现localhost以及127.0.0.1才能访问到navigator.gpu,直接使用ip会变成undefined,原因是为了用户的隐私安全,只能在安全的上下文中使用,非安全的上下文就会是undefined,安全上下…

SHAP中使用shap.summary_plot对多分类任务模型中特征重要性绘图

在文心一言中输入: 使用shap.summary_plot展示各个特征对模型输出类别的重要性 其输出的代码为(不正确): from sklearn import datasets from sklearn.model_selection import train_test_split from sklearn import svm import …

git clone中的报错问题解决:git@github.com: Permission denied (publickey)

报错: Submodule path ‘kernels/3rdparty/llm-awq’: checked out ‘19a5a2c9db47f69a2851c83fea90f81ed49269ab’ Submodule path ‘kernels/3rdparty/nvbench’: checked out ‘75212298727e8f6e1df9215f2fcb47c8c721ffc9’ Submodule path ‘kernels/3rdparty/t…

为什么 Swift 没有原生的 subArray 方法?

为什么 Swift 没有原生的 subArray 方法? Swift 是一门设计精良的编程语言,以其灵活性和高性能著称。在 Swift 中截取数组的子数组是一个常见的操作,但你可能会发现 Swift 标准库中并没有直接提供一个 subArray 方法。这是为什么呢&#xff…

软考中级软件设计师查成绩:终于合格了。

软考中级软件设计师终于合格了。 考试时间是8:30-12:30,我下午一点多要赶火车。考试的地方很偏僻,离火车站30多里地。所以,我必须提前交卷。客观题有大概10道题都是蒙的C。应用题中的算法考的是哈夫曼算法&#xff0…

【python】PyQt5各个控件语法解析,QObject父子对象的操作

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,…

Python文本挖掘数据分析——竞争分析(1)

文章目录 前言项目背景与目标品类分布分析数据准备与处理查看数据类目作图查看占比的不同 适用对象作图查看适用对象占比 产品结构分析对商品分类汇总定义作图函数拜耳安速科凌虫控 前言 数据说明: 项目背景与目标 该项目旨在分析三个品牌(拜耳、安速、科凌虫控&…