【JSリファレンス】Atomicsオブジェクト
更新日:2024/06/14
Atomicsオブジェクトは、TypedArrayへの読み書きをアトミック(不可分)な操作で行います。
アトミック操作とは、異なるスレッドが同じメモリ領域を操作する際に、一つのスレッドの一連の処理を途中で分割されることなく完了させ、その後に他のスレッドの処理を行うように制御することを指します。
JavaScriptは、スレッド間でメモリ共有する手段としてSharedArrayBufferコンストラクターが用意されています。
Atomicsオブジェクトは、SharedArrayBufferコンストラクターのビューであるTypedArrayに対してアトミック操作を行います。
■使用例
以降のコードは、Node.jsを想定しています。
実行結果は実行環境により異なります。
メインスレッド:
const {Worker} = require("worker_threads");
const buffer = new SharedArrayBuffer(
Int32Array.BYTES_PER_ELEMENT*2);
new Worker("worker.js", { workerData:buffer });
const i32Array = new Int32Array(buffer);
setTimeout(()=>{
// Workerに合図を送る
Atomics.notify(i32Array, 1, 1);
for(let i = 0;i < 500 ;i++){
const before = Atomics.add( i32Array , 0 , 3 );
const after = Atomics.load(i32Array,0);
console.log( `main:${before} => ${after}` );
}
},1000);
Workerスレッド:worker.js
const {workerData:buffer} = require("worker_threads");
const i32Array = new Int32Array(buffer);
// メインの開始合図まで停止する
Atomics.wait(i32Array,1,0);
for(let i = 0;i < 500 ;i++){
const before = Atomics.add( i32Array , 0 , 3 );
const after = Atomics.load(i32Array,0);
console.log( `worker:${before} => ${after}` );
}
ブラウザはSharedArrayBufferコンストラクターの使用が制限されます。
詳しくは次のページを参照してください。
■プロパティ
■メソッド
関連ページ
更新日:2024/06/14
スポンサーリンク
記事の内容について
こんにちはけーちゃんです。
説明するのって難しいですね。
「なんか言ってることおかしくない?」
たぶん、こんなご意見あると思います。
裏付けを取りながら記事を作成していますが、僕の勘違いだったり、そもそも情報源の内容が間違えていたりで、正確でないことが多いと思います。
そんなときは、ご意見もらえたら嬉しいです。
掲載コードについては事前に動作確認をしていますが、貼り付け後に体裁を整えるなどをした結果動作しないものになっていることがあります。
生暖かい視線でスルーするか、ご指摘ください。
ご意見、ご指摘はこちら。
https://jsref.affi-sapo-sv.com/info.php
このサイトは、リンクフリーです。大歓迎です。