aboutsummaryrefslogtreecommitdiff
path: root/files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md
diff options
context:
space:
mode:
Diffstat (limited to 'files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md')
-rw-r--r--files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md64
1 files changed, 26 insertions, 38 deletions
diff --git a/files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md b/files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md
index ea5e985410..3d2bf2134d 100644
--- a/files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md
+++ b/files/ja/web/javascript/reference/global_objects/atomics/compareexchange/index.md
@@ -6,75 +6,63 @@ tags:
- JavaScript
- メソッド
- 共有メモリー
- - メソッド
- - 共有メモリ
+browser-compat: javascript.builtins.Atomics.compareExchange
translation_of: Web/JavaScript/Reference/Global_Objects/Atomics/compareExchange
---
{{JSRef}}
-静的な <strong>Atomics</strong><strong>.compareExchange()</strong> メソッドは、指定された値を配列内の指定した位置に格納し、その値を返します。
+静的な **`Atomics.compareExchange()`** メソッドは、指定された値を配列内の指定した位置に格納し、その値を返します。これは、その位置での古い値が、期待された値と同じであったかどうかを返すものです。これは不可分操作で、変更された値が書き戻されるまで、他の書き込みが行われないことが保証されます。
{{EmbedInteractiveExample("pages/js/atomics-compareexchange.html")}}
-<div class="hidden">このデモのソースファイルは GitHub リポジトリに格納されています。デモプロジェクトに協力したい場合は、 <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples</a> をクローンしてプルリクエストを送信してください。</div>
-
## 構文
-<pre class="syntaxbox">Atomics.compareExchange(typedArray, index, value)
-</pre>
+```js
+Atomics.compareExchange(typedArray, index, expectedValue, replacementValue)
+```
### 引数
-- typedArray
- <dd>共有整数型付き配列です。 {{jsxref("Int8Array")}}, {{jsxref("Uint8Array")}}, {{jsxref("Int16Array")}}, {{jsxref("Uint16Array")}}, {{jsxref("Int32Array")}}, {{jsxref("Uint32Array")}} の何れかです。</dd>
-- index
- <dd>typedArray で value と交換する位置です。</dd>
-- expectedValue
- <dd>等価性をチェックする値です。</dd>
-- replacementValue
- <dd>交換する数値です。</dd>
+- `typedArray`
+ - : 共有整数の型付き配列です。 {{jsxref("Int8Array")}}, {{jsxref("Uint8Array")}}, {{jsxref("Int16Array")}}, {{jsxref("Uint16Array")}}, {{jsxref("Int32Array")}}, {{jsxref("Uint32Array")}} の何れかです。
+- `index`
+ - : `typedArray` で `value` と交換する位置です。
+- `expectedValue`
+ - : 等価性をチェックする値です。
+- `replacementValue`
+ - : 交換する数値です。
### 返値
-指定された位置にあった古い値です (typedArray[index])。
+指定された位置 (`typedArray[index]`) にあった古い値です。
### 例外
-- typedArray が許可された整数型の何れでもない場合、{{jsxref("TypeError")}} が発生します。
-- typedArray が共有型付き配列型ではない場合、 {{jsxref("TypeError")}} が発生します。
-- index が typedArray の範囲を超えている場合、 {{jsxref("RangeError")}} が発生します。
+- `typedArray` が許可された整数型の何れでもない場合、{{jsxref("TypeError")}} が発生します。
+- `index` が `typedArray` の範囲を超えている場合、 {{jsxref("RangeError")}} が発生します。
## 例
-<h3 id="Using_compareExchange" name="Using_compareExchange">compareExchange() の使用</h3>
+### compareExchange() の使用
-<pre class="brush: js">const sab = new SharedArrayBuffer(1024);
+```js
+const sab = new SharedArrayBuffer(1024);
const ta = new Uint8Array(sab);
ta[0] = 7;
Atomics.compareExchange(ta, 0, 7, 12); // returns 7, the old value
-Atomics.load(ta, 0); // 12</pre>
+Atomics.load(ta, 0); // 12
+```
-<h2 id="Specifications" name="Specifications">仕様書</h2>
+## 仕様書
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">仕様書</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-atomics.compareexchange', 'Atomics.compareExchange')}}</td>
- </tr>
- </tbody>
-</table>
+{{Specifications}}
-<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2>
+## ブラウザーの互換性
-{{Compat("javascript.builtins.Atomics.compareExchange")}}
+{{Compat}}
-<h2 id="See_also" name="See_also">関連情報</h2>
+## 関連情報
- {{jsxref("Atomics")}}
- {{jsxref("Atomics.exchange()")}}