Baseline Widely available
La méthode statique Atomics.or()
calcule le résultat d'un OU binaire entre une valeur donnée et une valeur du tableau typé et y place le résultat obtenu. Cette opération atomique garantit qu'aucune autre opération d'écriture n'est appliquée tant que la valeur modifiée n'est pas écrite.
// Create a SharedArrayBuffer with a size in bytes
const buffer = new SharedArrayBuffer(16);
const uint8 = new Uint8Array(buffer);
uint8[0] = 5;
// 5 (0101) OR 2 (0010) = 7 (0111)
console.log(Atomics.or(uint8, 0, 2));
// Expected output: 5
console.log(Atomics.load(uint8, 0));
// Expected output: 7
Syntaxe
Atomics.or(typedArray, index, value);
Paramètres
typedArray
Un tableau typé entier partagé parmi Int8Array
, Uint8Array
, Int16Array
, Uint16Array
, Int32Array
ou Uint32Array
.
index
La position du tableau typedArray
sur laquelle calculer le OU binaire.
valeur
Le nombre avec lequel calculer le OU binaire.
L'ancienne valeur contenue à l'emplacement du tableau (typedArray[index]
).
TypeError
si le type de typedArray
n'est pas un des types entiers autorisés.TypeError
si typedArray
n'est pas tableau typé partagé.RangeError
si index
est en dehors des limites de typedArray
.L'opération binaire OU renvoie 1 si a
ou b
valent 1. La table de vérité de cette opération est :
a
b
a | b
0 0 0 0 1 1 1 0 1 1 1 1
Par exemple, un OU binaire appliqué entre 5 et 1 (5 | 1
) renvoie 0101
, ce qui correspond à 5 en notation décimale.
5 0101 1 0001 ---- 5 0101Exemples
var sab = new SharedArrayBuffer(1024);
var ta = new Uint8Array(sab);
ta[0] = 2;
Atomics.or(ta, 0, 1); // renvoie 2, l'ancienne valeur
Atomics.load(ta, 0); // 3
Spécifications Compatibilité des navigateurs Voir aussi
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4