This is an experimental technology
Because this technology's specification has not stabilized, check the compatibility table for usage in various browsers. Also note that the syntax and behavior of an experimental technology is subject to change in future versions of browsers as the specification changes.
The static Atomics
.wait()
method verifies that a given position in an Int32Array
still contains a given value and sleeps awaiting or times out. It returns a string which is either "ok"
, "not-equal"
, or "timed-out"
.
Note: This operation only works with a shared Int32Array
and is not allowed on the main thread.
Atomics.wait(typedArray, index, value[, timeout])
typedArray
Int32Array
.index
typedArray
to wait on.value
timeout
Optional
Infinity
, if no time is provided.A String
which is either "ok
", "not-equal
", or "timed-out
".
TypeError
, if typedArray
is not a shared Int32Array
.RangeError
, if index
is out of bounds in the typedArray
.Given a shared Int32Array
:
var sab = new SharedArrayBuffer(1024); var int32 = new Int32Array(sab);
A reading thread is sleeping and waiting on location 0 which is expected to be 0. As long as that is true, it will not go on. However, once the writing thread has stored a new value, it will be woken up by the writing thread and return the new value (123).
Atomics.wait(int32, 0, 0); console.log(int32[0]); // 123
A writing thread stores a new value and wakes up the waiting thread once it has written:
console.log(int32[0]); // 0; Atomics.store(int32, 0, 123); Atomics.wake(int32, 0, 1);
Specification | Status | Comment |
---|---|---|
ECMAScript Shared Memory and Atomics The definition of 'Atomics.wait' in that specification. | Draft | Initial definition. |
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|---|
Basic support | No support [2] | No support | 52 (52) [1] [3] | No support | No support | No support |
Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | No support | No support | 52.0 (52) [1] | No support | No support | No support |
[1] In Firefox version 46 until version 51, this feature was disabled by a preference setting. In about:config, set javascript.options.shared_memory
to true
.
[2] The implementation is under development and needs these runtime flags: --js-flags=--harmony-sharedarraybuffer --enable-blink-feature=SharedArrayBuffer
[3] In versions 46 and 47, this method was named Atomics.futexWait()
and the properties Atomics.OK
, Atomics.TIMEDOUT
, Atomics.NOTEQUAL
were returned instead of the strings.
© 2005–2017 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Atomics/wait