アトミック-クイックガイド

原子物理学

Atomicsは、静的メソッドとして実行されるアトミック操作を提供するJavaScriptのオブジェクトです。Mathオブジェクトのメソッドと同様に、Atomicsのメソッドとプロパティも静的です。アトミックはSharedArrayBufferオブジェクトで使用されます。

アトミック操作は、アトミックモジュールにインストールされます。他のグローバルオブジェクトとは異なり、Atomicsはコンストラクターではありません。アトミックは、新しい演算子で使用したり、関数として呼び出すことができます。

不可分操作

アトミック操作は中断できません。

メモリが共有されている場合、複数のスレッドがメモリ内の既存のデータを読み書きできます。したがって、データが変更された場合、データが失われます。アトミック操作では、予測値(データ)が正確に書き込まれ、読み取られることを確認してください。アトミック操作は、現在の操作が終了するまで開始されないため、既存のデータを変更する方法はありません。

以下は、JavaScriptアトミック操作の使用を示すコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.add(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            container.innerHTML = Atomics.add(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

原子物理学

Atomicsは、静的メソッドとして実行されるアトミック操作を提供するJavaScriptのオブジェクトです。Mathオブジェクトのメソッドと同様に、Atomicsのメソッドとプロパティも静的です。アトミックはSharedArrayBufferオブジェクトで使用されます。

アトミック操作は、アトミックモジュールにインストールされます。他のグローバルオブジェクトとは異なり、Atomicsはコンストラクターではありません。アトミックは、新しい演算子で使用したり、関数として呼び出すことができます。

不可分操作

アトミック操作は中断できません。

メモリが共有されている場合、複数のスレッドがメモリ内の既存のデータを読み書きできます。したがって、データが変更された場合、データが失われます。アトミック操作では、予測値(データ)が正確に書き込まれ、読み取られることを確認してください。アトミック操作は、現在の操作が終了するまで開始されないため、既存のデータを変更する方法はありません。

以下は、JavaScriptアトミック操作の使用を示すコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.add(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            container.innerHTML = Atomics.add(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

addメソッドは、配列内の指定された位置に指定された値を追加します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.add(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • value 追加されます。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.add(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            container.innerHTML = Atomics.add(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

andメソッドは、配列内の指定された位置で指定された値を使用してビット単位のANDを計算します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.and(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • value どのビットごとのANDを計算するか。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.and(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            //6 & 2 = 110 & 010 = 010 = 2
            container.innerHTML = Atomics.and(arr, 0, 2) + '<br/>'+ Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

compareExchange指定された値が古い値と同じでない場合、メソッドは置換値を比較して交換します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.compareExchange(typedArray, index, expectedValue, replacementValue)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • expectedValue 同等性をチェックします。

  • replacementValue 交換します。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.compareExchange(arr, 0, 6, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            container.innerHTML = Atomics.compareExchange(arr, 0, 6, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

exchangeメソッドは、配列の指定された位置で指定された値を交換します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.exchange(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • value 交換します。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.exchange(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            container.innerHTML = Atomics.exchange(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

isLockFreeメソッドは、ロックをアトミック操作に使用するかどうかを決定するために使用されます。指定されたサイズが整数TypedArrayタイプのTypedArray.BYTES_PER_ELEMENTプロパティのいずれかである場合、trueを返します。TypedArray.BYTES_PER_ELEMENTは、型付き配列の各要素のサイズをバイト単位で表します。

構文

Atomics.isLockFree(size)

パラメーター

  • size バイト単位でチェックされます。

戻る

操作がfalseとしてロックされていない場合はtrueを返します。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.isLockFree(1)</p>
      <p>Atomics.isLockFree(3)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            // Int8Array.BYTES_PER_ELEMENT = 1
            container.innerHTML = Atomics.isLockFree(Int8Array.BYTES_PER_ELEMENT) + '<br/>' + Atomics.isLockFree(3);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

load メソッドは、配列内の指定された位置に値を返します。

構文

Atomics.load(typedArray, index)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

戻る

指定された位置の値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.add(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            container.innerHTML = Atomics.add(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

notifyメソッドは、待機中のエージェントにウェイクアップを通知します。notifyメソッドは、SharedArrayBufferを使用して作成されたInt32Arrayでのみ機能します。非共有ArrayBufferオブジェクトが使用されている場合は、0を返します。

構文

Atomics.notify(typedArray, index, count)

パラメーター

  • typedArray 共有Int32Arrayです。

  • index ウェイクアップするtypedarray内の位置です。

  • count 通知するスリープエージェントの数です。

戻る

ウェイクアップしたエージェントの数を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.store(arr, 0, 5)</p>
      <p>Atomics.notify(arr, 0, 1)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(16);
            var arr = new Int32Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;            
            container.innerHTML = Atomics.store(arr, 0, 5) + '<br>' + Atomics.notify(arr, 0, 1);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

orメソッドは、配列内の指定された位置で指定された値を使用してビットごとのORを計算します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.or(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • value どのビットごとのORを計算するか。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.or(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            //6 | 2 = 110 | 010 = 110 = 6
            container.innerHTML = Atomics.or(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

storeメソッドは、配列内の指定された場所に値を格納し、同じ値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.store(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index 値が格納されるtypedarray内の位置です。

  • value 保存する。

戻る

指定された位置に格納されている値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.store(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;           
            container.innerHTML = Atomics.store(arr, 0, 2) + '<br/>'
            + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

subメソッドは、配列内の指定された位置で指定された値を減算します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.sub(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • value 差し引かれます。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.sub(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            //6 - 2 = 4
            container.innerHTML = Atomics.sub(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。

xorメソッドは、配列内の指定された位置で指定された値を使用してビット単位のXORを計算します。その位置の古い値を返します。このアトミック操作により、変更された値が書き戻されるまで、他の書き込みが発生しないことが保証されます。

構文

Atomics.xor(typedArray, index, value)

パラメーター

  • typedArray 整数型の配列です。

  • index typedarray内の位置です。

  • value どのビット単位のXORを計算するか。

戻る

指定された位置の古い値を返します。

例外

  • TypeError 渡された配列が整数型の配列でない場合。

  • RangeError 渡されたインデックスが型付き配列の範囲外である場合。

以下は、JavaScriptアトミックを実装するためのコードです-

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8" />
      <meta name="viewport" content="width=device-width, initial-scale=1.0" />
      <title>Atomics Example</title>
      <style>
         .result {
            font-size: 20px;
            border: 1px solid black;
         }
      </style>
   </head>
   <body onLoad="operate();">
      <h1>JavaScript Atomics Properties</h1>
      <div class="result"></div>
      <p>Atomics.xor(arr, 0, 2)</p>
      <p>Atomics.load(arr, 0)</p>
      <script>
         function operate(){
            let container = document.querySelector(".result");
            // create a SharedArrayBuffer
            var buffer = new SharedArrayBuffer(25);
            var arr = new Uint8Array(buffer);
            // Initialise element at zeroth position of array with 6
            arr[0] = 6;
            //6 xor 2 = 110 xor 010 = 100 = 4
            container.innerHTML = Atomics.xor(arr, 0, 2) + '<br/>' + Atomics.load(arr, 0);
         }
      </script>
   </body>
</html>

出力

結果を確認します。