Baseline Widely available
La méthode statique Atomics.xor()
calcule le résultat d'un OU exclusif (XOR) binaire entre une valeur donnée et une valeur du tableau partagé à un emplacement donné. Elle renvoie l'ancienne valeur qui était contenue à cette position. 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] = 7;
// 7 (0111) XOR 2 (0010) = 5 (0101)
console.log(Atomics.xor(uint8, 0, 2));
// Expected output: 7
console.log(Atomics.load(uint8, 0));
// Expected output: 5
Syntaxe
Atomics.xor(typedArray, index, valeur);
Paramètres
typedArray
Un tableau typé entier partagé parmi Int8Array
, Uint8Array
, Int16Array
, Uint16Array
, Int32Array
ou Uint32Array
.
index
La position du tableau typedArray
à laquelle calculer le OU exclusif binaire.
valeur
La valeur avec laquelle on souhaite calculer le OU exclusif binaire.
L'ancienne valeur située à cet 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 exclusif (XOR) renvoie 1 si a
et b
sont différents. La table de vérité correspondante est :
a
b
a ^ b
0 0 0 0 1 1 1 0 1 1 1 0
Par exemple, le calcul d'un OU exclusif binaire entre 5 et 1 (5 ^ 1
) renvoie 0100
, qui correspond à 4 en notation décimale.
5 0101 1 0001 ---- 4 0100Exemples
var sab = new SharedArrayBuffer(1024);
var ta = new Uint8Array(sab);
ta[0] = 5;
Atomics.xor(ta, 0, 1); // renvoie 5, l'ancienne valeur
Atomics.load(ta, 0); // 4
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