blob: 313fc0577e35305858273d7b27a95ffba2730db8 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
---
title: Atomics.sub()
slug: Web/JavaScript/Reference/Global_Objects/Atomics/sub
tags:
- Atomics
- JavaScript
- Mémoire partagée
- Méthode
- Reference
translation_of: Web/JavaScript/Reference/Global_Objects/Atomics/sub
original_slug: Web/JavaScript/Reference/Objets_globaux/Atomics/sub
---
<div>{{JSRef}}</div>
<p>La méthode statique <code><strong>Atomics</strong></code><strong><code>.sub()</code></strong> permet de soustraire une valeur donnée à une position donnée du tableau partagé. Elle renvoie l'ancienne valeur qui était contenue dans le tableau avant l'opération. 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.</p>
<div>{{EmbedInteractiveExample("pages/js/atomics-sub.html")}}</div>
<h2 id="Syntaxe">Syntaxe</h2>
<pre class="syntaxbox">Atomics.sub(typedArray, index, valeur)
</pre>
<h3 id="Paramètres">Paramètres</h3>
<dl>
<dt><code>typedArray</code></dt>
<dd>Un tableau typé entier partagé parmi {{jsxref("Int8Array")}}, {{jsxref("Uint8Array")}}, {{jsxref("Int16Array")}}, {{jsxref("Uint16Array")}}, {{jsxref("Int32Array")}} ou {{jsxref("Uint32Array")}}.</dd>
<dt><code>index</code></dt>
<dd>La position du tableau typé <code>typedArray</code> à laquelle on veut soustraire <code>valeur</code>.</dd>
<dt><code>valeur</code></dt>
<dd>La quantité qu'on souhaite soustraire.</dd>
</dl>
<h3 id="Valeur_de_retour">Valeur de retour</h3>
<p>L'ancienne valeur qui était contenue à (<code>typedArray[index]</code>).</p>
<h3 id="Exceptions_levées">Exceptions levées</h3>
<ul>
<li>Cette méthode lève {{jsxref("TypeError")}} si le type de <code>typedArray</code> n'est pas un des types entiers autorisés.</li>
<li>Cette méthode lève {{jsxref("TypeError")}} si <code>typedArray</code> n'est pas tableau typé partagé.</li>
<li>Cette méthode lève {{jsxref("RangeError")}} si <code>index</code> est en dehors des limites de <code>typedArray</code>.</li>
</ul>
<h2 id="Exemples">Exemples</h2>
<pre class="brush: js">var sab = new SharedArrayBuffer(1024);
var ta = new Uint8Array(sab);
ta[0] = 48;
Atomics.sub(ta, 0, 12); // renvoie 48, l'ancienne valeur
Atomics.load(ta, 0); // 36
</pre>
<h2 id="Spécifications">Spécifications</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Spécification</th>
<th scope="col">État</th>
<th scope="col">Commentaires</th>
</tr>
<tr>
<td>{{SpecName('ESDraft', '#sec-atomics.sub', 'Atomics.sub')}}</td>
<td>{{Spec2('ESDraft')}}</td>
<td>Définition initiale avec ES2017.</td>
</tr>
</tbody>
</table>
<h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2>
<p>{{Compat("javascript.builtins.Atomics.sub")}}</p>
<h2 id="Voir_aussi">Voir aussi</h2>
<ul>
<li>{{jsxref("Atomics")}}</li>
<li>{{jsxref("Atomics.add()")}}</li>
</ul>
|