0

0

什么是JavaScript的Web Workers_它如何实现多线程编程?

夢幻星辰

夢幻星辰

发布时间:2025-12-15 06:01:34

|

333人浏览过

|

来源于php中文网

原创

Web Workers 是基于消息传递的后台线程机制,实现主线程不阻塞的多线程编程;其通过 postMessage/onmessage 通信,数据经结构化克隆复制,支持 Transferable Objects 零拷贝,天然规避竞态条件。

什么是javascript的web workers_它如何实现多线程编程?

Web Workers 是 JavaScript 提供的一种在后台线程中运行脚本的机制,它让开发者能真正实现多线程编程——主线程不被阻塞,耗时任务(如大量计算、数据处理)可交给独立线程执行。

Web Workers 的核心特点

它不是“共享内存式”多线程,而是基于消息传递(message passing)的隔离线程模型:

  • 每个 Worker 运行在独立的全局上下文中,无法直接访问 DOM、window 或 document
  • 主线程与 Worker 之间通过 postMessage()onmessage 通信,数据通过结构化克隆算法复制(非共享引用)
  • Worker 脚本必须来自同源 URL(不能是内联脚本或 data URL)
  • 支持专用 Worker(Dedicated Worker)、共享 Worker(Shared Worker)和 Service Worker,最常用的是 Dedicated Worker

如何创建并使用一个专用 Worker

分两步:编写 Worker 脚本 + 在主线程中实例化并通信:

  • 新建文件 worker.js,写入要后台执行的逻辑,例如:
    self.onmessage = function(e) {
    const result = e.data * e.data;
    self.postMessage(result);
    };
  • 主线程中:
    const worker = new Worker('worker.js');
    worker.postMessage(123); // 发送数据
    worker.onmessage = function(e) { console.log('结果:', e.data); };
  • 注意:Worker 内部用 self 代替 window,可用 fetchsetTimeoutWebAssembly 等,但不能用 alertlocalStorage(部分浏览器限制)

为什么说它“模拟”了多线程而非真正共享内存?

JavaScript 引擎本身是单线程的,V8 等引擎通过操作系统级线程来托管 Worker,但 JS 层面不暴露线程控制权。所有跨线程数据都需序列化/反序列化:

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

iOS开发学习之iOS多线程和RunLoop 中文WORD版
iOS开发学习之iOS多线程和RunLoop 中文WORD版

iOS多线程编程对于iOS开发初学者来说,总是会觉得很难理解和掌握,现在通过几个实例来更加系统全面的理解iOS多线程编程,希望对大家有所帮助。 有些程序是一条直线,起点到终点;有些程序是一个圆,不断循环,直到将它切断。直线的如简单的Hello World,运行打印完,它的生命周期便结束了,像昙花一现那样;圆如操作系统,一直运行直到你关机。 一个运行着的程序就是一个进程或者叫做一个任务,一个进程至少包含一个线程,线程就是程序的执行流。Mac和iOS中的程序启动,创建好一个进程的同时,一个线程便开始运行,

下载
  • 传对象时,只有可克隆属性被复制(函数、undefined、Symbol、Promise 等会被忽略)
  • 大数组可使用 Transferable Objects(如 ArrayBuffer)零拷贝传输,提升性能:worker.postMessage(buffer, [buffer]);
  • 有锁、没有共享变量,天然规避了竞态条件——这也意味着它不适合需要频繁读写同一状态的场景

适用与不适用的场景

适合:图像处理、加密解密、JSON 解析/生成、游戏 AI 计算、离线数据预处理等 CPU 密集型任务。

不适合:需要操作 DOM 的任务(必须回调主线程)、I/O 主导且不耗 CPU 的简单请求(fetch 本身已是异步,无需 Worker)、轻量级逻辑(启动 Worker 有开销,约几毫秒)。

基本上就这些。Web Workers 不复杂但容易忽略它的通信本质——它不是让 JS 变成多线程语言,而是给你开了一个“不打扰用户界面”的新窗口去干活。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

419

2023.08.07

json是什么
json是什么

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

535

2023.08.23

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

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

311

2023.10.13

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

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

77

2025.09.10

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

531

2023.09.20

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

503

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

166

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

15

2026.01.21

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

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

精品课程

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

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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