书籍详情

JavaScript多线程编程实践

JavaScript多线程编程实践

作者:[美]托马斯 亨特二世(Thomas Hunter II),[加拿大]布莱恩 英格利什(Bryan English)

出版社:中国电力出版社

出版时间:2023-12-01

ISBN:9787519883416

定价:¥78.00

购买这本书可以去
内容简介
  本书主要讨论了构建多线程应用的两种方法:一种是使用消息传递,另一种是使用共享内存。你将学习实现每种方法的API,包括根据情况进行选择,以及何时可以结合使用它们。你还将亲自动手实践这些方法构建的高级模式。本书的主要内容有:学习如何从多线程编程中受益。了解专用 worker、共享 worker和服务 worker之间的区别。知道何时以及何时不应该在应用程序中使用多线程。通过利用Atomics对象协调线程之间的通信。应用这些知识来构建高性能的应用程序。从多线程中受益的评估方式。
作者简介
  Thomas Hunter II为数十个企业级Node.js服务做出了贡献,并曾在一家致力于保障Node.js安全的公司工作。他在多个关于Node.js和JavaScript的会议上发表过演讲,拥有JSNSD/JSNAD认证,并且是NodeSchool SF的组织者。Bryan English是一位开源JavaScript和Rust程序员,他曾在大型企业系统、仪表盘和应用安全方面工作过。作为Datadog的高级开源软件工程师,Bryan是Node.js核心协作者,为多个工作组做出了贡献。
目录
目录
序 1
前言 3
目录
第1 章 概述 9
1.1 什么是线程 11
1.2 并发性和并行性 13
1.3 单线程的JavaScript .15
1.4 隐藏的线程 18
1.5 C 语言中的线程:用快乐币致富 . 20
1.5.1 仅用一个主线程 21
1.5.2 使用4 个工作线程 .24
第2 章 浏览器 29
2.1 专用worker .30
2.1.1 专用worker 的Hello World 30
2.1.2 专用worker 的高级用法 .34
2.2 共享worker .36
2.2.1 共享worker 的Hello World 38
2.2.2 共享worker 的高级用法 .44
2.3 service worker .47
2.3.1 service worker 的Hello World 49
2.3.2 service worker 的高级概念 .55
2.4 消息传递的抽象 58
2.4.1 RPC 模式 .58
2.4.2 命令调度器模式 60
2.4.3 混合模式 .62
第3 章 Node.js .71
3.1 在拥有线程之前 72
3.2 worker_threads 模块 75
3.2.1 workerData .76
3.2.2 MessagePort 77
3.3 再次看快乐币(Happycoin)这个程序 .79
3.3.1 单线程版本 80
3.3.2 四个线程的版本 82
3.4 带有Piscina 的worker 池 .85
3.5 一个完整的池化快乐币的例子 90
第4 章 共享内存 95
4.1 共享内存简介 .96
4.1.1 浏览器中的共享内存.96
4.1.2 在Node.js 中的共享内存 . 100
4.2 SharedArrayBuffer 和TypedArrays 102
4.3 数据操作的原子方法 108
4.3.1 Atomics.add() . 109
4.3.2 Atomics.and() . 109
4.3.3 Atomics.compareExchange() 110
4.3.4 Atomics.exchange() . 110
4.3.5 Atomics.isLockFree() . 110
4.3.6 Atomics.load() 111
4.3.7 Atomics.or() 111
4.3.8 Atomics.store() 111
4.3.9 Atomics.sub() . 112
4.3.10 Atomics.xor() 112
4.4 原子性问题 112
4.5 数据序列化 116
4.5.1 布尔值 116
4.5.2 字符串 118
4.5.3 对象 . 120
第5 章 高级共享内存 121
5.1 原子协调方法 121
5.1.1 Atomics.wait() 122
5.1.2 Atomics.notify() 124
5.1.3 Atomics.waitAsync() 124
5.2 时间和不确定性 . 125
5.2.1 不确定性的例子 125
5.2.2 检测线程准备情况 129
5.3 示例应用:康威生命游戏 . 132
5.3.1 单线程生命游戏 133
5.3.2 多线程生命游戏 139
5.4 原子和事件 146
第6 章 多线程模式 149
6.1 线程池 . 149
6.1.1 线程池的大小 . 150
6.1.2 调度策略 152
6.1.3 应用实例 153
6.2 互斥锁:一个基本的锁 161
6.3 用环形缓冲器处理数据流 . 167
6.4 演员模型. 176
6.4.1 模式差异 177
6.4.2 与JavaScript 的关联 178
6.4.3 示例实现 179
第7 章 WebAssembly . 189
7.1 你的第一个WebAssembly .190
7.2 WebAssembly 中的原子操作 192
7.3 用Emscripten 将C 程序编译成WebAssembly 194
7.4 其他WebAssembly 编译器 196
7.5 AssemblyScript 197
7.6 AssemblyScript 中的快乐币 199
第8 章 分析 . 205
8.1 何时不使用 205
8.1.1 低内存限制 . 206
8.1.2 低核心数 209
8.1.3 容器与线程 . 213
8.2 何时使用. 213
8.3 注意事项. 219
附录 结构化克隆算法 223
猜您喜欢

读书导航