这是一个实验中的功能
此功能某些浏览器尚在开发中,请参考浏览器兼容性表格以得到在不同浏览器中适合使用的前缀。由于该功能对应的标准文档可能被重新修订,所以在未来版本的浏览器中该功能的语法和行为可能随之改变。
Atomics.compareExchange() 静态方法会在数组的值与期望值相等的时候,将给定的替换值替换掉数组上的值,然后返回旧值。此原子操作保证在写上修改的值之前不会发生其他写操作。
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.
语法
Atomics.compareExchange(typedArray, index, expectedValue, replacementValue)
参数
-
typedArray -
一个共享的整型 typed array。例如
Int8Array,Uint8Array,Int16Array,Uint16Array,Int32Array,或Uint32Array。 -
index -
typedArray的索引。 -
expectedValue - 用于比较的值。
- replacementValue
- 将要替换上的值。
返回值
给定位置的旧值(typedArray[index]).
错误
- 假如
typedArray不是允许的整型之一,则抛出TypeError。 假如 typedArray不是一个贡献的 typed array,则抛出TypeError。- 如果
index超出了typedArray 的边界,则抛出RangeError。
示例
var sab = new SharedArrayBuffer(1024); var ta = new Uint8Array(sab); ta[0] = 7; Atomics.compareExchange(ta, 0, 7, 12); // returns 7, the old value Atomics.load(ta, 0); // 12
规范
| Specification | Status | Comment |
|---|---|---|
| Unknown Atomics.compareExchange |
Unknown | Initial definition. |
浏览器支持
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.
Update compatibility data on GitHub
| Desktop | Mobile | Server | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
compareExchange |
Chrome Full support 68
|
Edge No support 16 — 17
|
Firefox Full support 57
|
IE No support No | Opera No support No | Safari No support 10.1 — ? | WebView Android No support 60 — 63
|
Chrome Android No support 60 — 63
|
Firefox Android Full support 57
|
Opera Android No support No | Safari iOS No support No | Samsung Internet Android No support No
|
nodejs Full support 8.10.0 |
Legend
- Full support
- Full support
- No support
- No support
- See implementation notes.
- See implementation notes.
- User must explicitly enable this feature.
- User must explicitly enable this feature.