logo图片
Atomics教程

Atomics 概述

Atomics

Atomics是 JavaScript 中的一个对象,它提供作为静态方法执行的Atomics操作。就像 Math 对象的方法一样,Atomics 的方法和属性也是静态的。 Atomics 与 SharedArrayBuffer 对象一起使用。
Atomics操作安装在Atomics模块上。与其他全局对象不同,Atomics 不是构造函数。 Atomics 不能与 new 运算符一起使用,也不能作为函数调用。

Atomics操作

Atomics操作是不间断的。
共享内存时,多个线程可以读取或写入内存中已存在的数据。因此,如果任何数据发生更改,就会丢失数据 Atomics操作确保准确写入和读取预测值(数据)。Atomics操作在当前操作完成之前不会开始,因此无法更改现有数据。

示例

以下是演示 JavaScript Atomics操作使用的代码-
<!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>
昵称: 邮箱:
Copyright © 2020 立地货 All Rights Reserved.
备案号:京ICP备14037608号-4