0

0

javascript如何理解Web Workers_如何实现多线程【教程】

夢幻星辰

夢幻星辰

发布时间:2026-01-31 17:35:27

|

570人浏览过

|

来源于php中文网

原创

Web Workers 是独立 JS 执行上下文而非真正多线程,与主线程内存隔离、仅通过 postMessage 通信;需用 transferable 实现零拷贝;SharedArrayBuffer 需跨域隔离策略和 Atomics 才能安全共享内存;Worker 应主动 close 而非依赖 terminate。

javascript如何理解web workers_如何实现多线程【教程】

Web Workers 本质不是“多线程”,而是独立的 JS 执行上下文

JavaScript 主线程永远是单线程的,Web Workers 并没有打破这一点。它只是启动一个**与主线程完全隔离、无法共享内存**的新 JS 环境,靠 postMessageonmessage 通信——这更接近“进程隔离”而非操作系统级线程。理解这点,才能避免踩坑:比如不能直接访问 documentwindow 或主线程的变量,也不能用 console.log(除非在 Worker 内部调用,且部分浏览器限制其输出位置)。

如何创建并正确通信:从 new Worker()transferable

Worker 文件必须是同源的独立 JS 文件,不能是内联字符串或 blob URL(除非明确用 Blob + URL.createObjectURL,但兼容性需留意)。通信时默认序列化数据,大数组会严重拖慢性能:

  • ArrayBufferTypedArray 时,用 postMessage(data, [data.buffer]) 实现零拷贝转移(data 在发送后变为空)
  • 不要传普通 ArrayObject 大数据,会触发深拷贝和 JSON 序列化,卡顿明显
  • 主线程监听用 worker.onmessage = e => {...},Worker 内用 self.onmessage = e => {...}(不能用 this

SharedArrayBuffer 能否真共享内存?得配 Atomics跨域策略

现代浏览器中,SharedArrayBuffer 确实允许主线程与 Worker 共享同一块内存,但它不是“开箱即用”的:

  • 必须开启跨域隔离(crossorigin="anonymous" + 响应头 Cross-Origin-Embedder-Policy: require-corpCross-Origin-Opener-Policy: same-origin
  • 读写必须用 Atomics.load()/Atomics.store(),裸读写会引发竞态,Atomics.wait() 才能实现阻塞等待
  • Chrome 92+ 默认禁用 SharedArrayBuffer(防幽灵漏洞),没配好策略会直接报 SharedArrayBuffer is not defined

Worker 生命周期与错误处理:别让 terminate() 成为唯一出口

Worker 不会自动销毁,长期运行可能内存泄漏。常见误操作包括:

上班人导航
上班人导航

上班人必备的职场办公导航网站

下载

立即学习Java免费学习笔记(深入)”;

  • 在 Worker 内抛出未捕获异常,只会触发 onerror,不会终止 Worker,后续消息仍可接收
  • 主线程调用 worker.terminate() 后,Worker 立即停止,所有定时器、fetch、onmessage 回调全丢弃——适合强制退出,但不适合优雅关闭
  • 推荐模式:Worker 收到 {type: 'exit'} 消息后,自行调用 self.close();主线程监听 worker.onmessage 确认后再释放引用

复杂点在于通信边界模糊时——比如计算中途被取消,Worker 里正在跑的 for 循环无法被中断,只能靠轮询 Atomics 标志位或拆成微任务分片执行。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

458

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

84

2025.09.10

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1091

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

852

2023.11.06

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

510

2023.11.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

781

2023.08.03

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

7

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6.2万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号