SharedArrayBuffer - JavaScript 编辑
SharedArrayBuffer
对象用来表示一个通用的,固定长度的原始二进制数据缓冲区,类似于 ArrayBuffer
对象,它们都可以用来在共享内存(shared memory)上创建视图。与 ArrayBuffer
不同的是,SharedArrayBuffer
不能被分离。
请注意,作为对Spectre的响应,所有主流浏览器均默认于2018年1月5日禁用SharedArrayBuffer
。 Chrome在启用了网站隔离功能的平台上的v67中重新启用了该功能,以防止出现Spectre风格的漏洞。
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.
语法
new SharedArrayBuffer(length)
参数
length
- 所创建的数组缓冲区的大小,以字节(byte)为单位。
返回值
一个大小指定的新 SharedArrayBuffer
对象。其内容被初始化为 0。
描述
分配及共享内存
为了将一个SharedArrayBuffer
对象从一个用户代理共享到另一个用户代理(另一个页面的主进程或者当前页面的一个 worker
)从而实现共享内存,我们需要运用 postMessage
和结构化克隆算法( structured cloning )。
结构化克隆算法接收被映射到一个新的 SharedArrayBuffers
对象上的 SharedArrayBuffers
对象与 TypedArrays
对象。在这两种映射下,这个新的 SharedArrayBuffer
对象会被传递到目标用户代理的接收函数上,导致在目标用户代理产生了一个新的私有 SharedArrayBuffer
对象(正如 ArrayBuffer
一样)。然而,这两个 SharedArrayBuffer
对象指向的共享数据块其实是同一个,并且在某一代理中的一个块的副作用将最终导致另一个代理具有可见性。
let sab = new SharedArrayBuffer(1024);
worker.postMessage(sab);
通过原子操作更新及同步来共享内存
共享内存能被同时创建和更新于工作者线程或主线程。依赖于系统(CPU,操作系统,浏览器),变化传递给所有上下文环境需要一段时间。需要通过 atomic 操作来进行同步。
接受 SharedArrayBuffer 对象的API
WebGLRenderingContext.bufferData()
WebGLRenderingContext.bufferSubData()
WebGL2RenderingContext.getBufferSubData()
需要 new 运算符来构造
SharedArrayBuffer
需要 new
运算符来构造一个构造函数. 作为函数来调用一个 SharedArrayBuffer
构造函数时,如果不用 new
运算符,将会抛出一个 TypeError
异常。
var sab = SharedArrayBuffer(1024);
// TypeError: calling a builtin SharedArrayBuffer constructor
// 必须用 new 来构造
var sab = new SharedArrayBuffer(1024);
属性
SharedArrayBuffer.length
SharedArrayBuffer
构造函数的 length 属性值为1。SharedArrayBuffer.prototype
- 允许所有
SharedArrayBuffer
对象的附加属性。
SharedArrayBuffer 原型对象
所有 SharedArrayBuffer
实例继承自 SharedArrayBuffer.prototype
。
属性
方法
规范
规范 | 状态 | 备注 |
---|---|---|
ECMAScript (ECMA-262) SharedArrayBuffer | Living Standard | Initial definition in ES2017. |
ECMAScript 2017 (ECMA-262) SharedArrayBuffer | Standard |
浏览器兼容性
BCD tables only load in the browser
The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
相关链接
Atomics
ArrayBuffer
- JavaScript typed arrays
- Web Workers
- parlib-simple – a simple library providing synchronization and work distribution abstractions.
- Shared Memory – a brief tutorial
A Taste of JavaScript’s New Parallel Primitives – Mozilla Hacks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论