进程和线程的区别以及Chrome中的常⻅进程

进程(Process)和线程(Thread)都是操作系统中用于多任务处理的概念。简单地说,一个进程就是一个程序的执行空间 ,而一个线程则是在执行空间内独立运行的执行路径

区别:

  1. 进程是系统分配资源的最小单位,线程是操作系统调度的最小单位。
  2. 各个进程之间是独立的,各个线程之间共享一些资源。
  3. 创建或销毁进程时,会涉及到比较多的系统资源,开销比较大,而线程的创建和销毁的开销相对较小。
  4. 进程与进程之间会有 IPC(进程间通信)的开销,而线程之间的 IPC 开销较小。

Chrome 中的进程

在 Chrome 浏览器中,会有多个进程同时运行:

  1. Browser 进程:负责管理整个浏览器的生命周期、显示窗口、处理用户操作等。
  2. Renderer 进程:负责一个 Tab 内关联的页面的渲染和运行,每个 Tab 都有一个独立的 Renderer 进程。
  3. GPU 进程:负责处理页面中使用的 WebGL 等 GPU 相关任务。
  4. Plugin 进程:负责运行插件,包括 Flash 等。
  5. Utility 进程:负责处理部分浏览器内部的任务,比如下载、DNS 等。

如果想让 JS 代码达到多线程并发执行的效果,可以使用 Web Workers。Web Workers 是运行在后台的 JavaScript 线程,可以让页面在主线程中执行 JS 代码的同时,创建一个或多个新的线程在后台执行耗时的任务。Web Workers 的 API 包括:

  1. Worker 构造函数:用于创建一个新的 Worker 线程。
  2. postMessage() 方法:用于向 Worker 线程发送数据。
  3. onmessage 事件:用于监听 Worker 线程发送回来的消息。

举个例子,可以使用如下代码创建一个 Worker 线程:

js 复制代码
// file: worker.js
self.addEventListener('message', function(e) {
  var data = e.data;
  self.postMessage(data);
}, false);

// file: main.js
var worker = new Worker('worker.js');
worker.addEventListener('message', function(e) {
  console.log('Worker said: ', e.data);
}, false);
worker.postMessage('Hello World');

在上面的例子中,我们在主线程中创建了一个 Worker 线程,向它发送了一条消息,并在 Worker 线程中处理这条消息,并将结果发回到主线程。这样就实现了多线程的并发执行效果。

相关推荐
Patrick_Wilson2 天前
从「框架内部报错」到「请求头被网关截断」:一次 Sentry 排障与前端 Cookie 误用复盘
前端·http·浏览器
Patrick_Wilson4 天前
router.replace 之后紧跟 reload,页面为什么无限刷新?
javascript·react.js·浏览器
爱看老照片4 天前
浏览器的同源策略以及跨源问题 ( 浏览器的同域策略以及跨域问题)
浏览器·web·同源策略·跨域
Bigger5 天前
记一次坑爹的 Cloudflare Pages 部署:Failed to load module script 是怎么把我的 SPA 搞挂的
前端·ci/cd·浏览器
米丘8 天前
浏览器 本地存储 (cookie 、sessionStorage、localStorage)
安全·http·浏览器
kyriewen9 天前
浏览器缓存最强攻略:强缓存、协商缓存、CDN、更新策略,一篇搞定
前端·面试·浏览器
米丘9 天前
HTTP 强缓存 和 协商缓存 (浏览器缓存)
http·node.js·浏览器
初心丨哈士奇11 天前
一行 # 的差别:彻底搞懂前端路由的 hash 和 history 模式
前端·浏览器
一念&13 天前
油猴脚本教程——元数据块
javascript·浏览器·脚本·油猴
streaker30317 天前
从复制 Token 到复用登录态:site-fetchkit 的抽离过程
前端·浏览器·ai编程