アトミック-概要
原子物理学
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>
出力
結果を確認します。