Cette page a été traduite à partir de l'anglais par la communauté. Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.

View in English Always switch to English

Atomics : méthode statique xor()

Baseline Widely available

Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis ⁨décembre 2021⁩.

La méthode statique Atomics.xor() calcule un OU Exclusif binaire (ou « XOR ») avec une valeur donnée à une position donnée dans le tableau, et retourne l'ancienne valeur à cette position. Cette opération atomique garantit qu'aucune autre écriture n'a lieu avant que la valeur modifiée ne soit réécrite.

Exemple interactif

// Crée un SharedArrayBuffer avec une taille en octets
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));
// Résultat attendu : 7

console.log(Atomics.load(uint8, 0));
// Résultat attendu : 5

Syntaxe

js
Atomics.xor(typedArray, index, value)

Paramètres

typedArray

Un tableau typé entier partagé parmi Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, BigInt64Array ou BigUint64Array.

index

La position du tableau typedArray à laquelle calculer le OU exclusif binaire.

value

La valeur avec laquelle on souhaite calculer le OU exclusif binaire.

Valeur de retour

L'ancienne valeur située à cet emplacement du tableau (typedArray[index]).

Exceptions

TypeError

Lèvee si typedArray n'est pas l'un des types d'entiers autorisés.

RangeError

Levée si index est en dehors des limites de typedArray.

Description

L'opération binaire OU exclusif (XOR) retourne 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 5 ^ 1 retourne 0100, qui correspond à 4 en notation décimale.

5  0101
1  0001
   ----
4  0100

Exemples

Utilisation de xor(s)

js
const sab = new SharedArrayBuffer(1024);
const ta = new Uint8Array(sab);
ta[0] = 5;

Atomics.xor(ta, 0, 1); // retourne 5, l'ancienne valeur
Atomics.load(ta, 0); // 4

Spécifications

Specification
ECMAScript® 2026 Language Specification
# sec-atomics.xor

Compatibilité des navigateurs

Voir aussi