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>

输出

验证结果。

Atomics - add() 方法

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>

输出

验证结果。

Atomics - add() 方法

add方法在数组中的给定位置添加提供的值。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.add(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 要添加的值。

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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>

输出

验证结果。

Atomics - and() 方法

and方法使用数组中给定位置处的提供值计算按位 AND。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.and(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 要计算按位与的值。

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics -compareExchange() 方法

如果给定值与旧值不同,compareExchange方法会比较并交换替换值。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

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

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 用于检查相等性的预期值。

  • 交换价值

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - Exchange() 方法

交换方法在数组的给定位置交换给定值。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.exchange(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 交换的价值。

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - isLockFree() 方法

isLockFree方法用于确定Atomics操作是否使用锁。如果给定大小是整数 TypedArray 类型的 TypedArray.BYTES_PER_ELEMENT 属性之一,则返回 true。TypedArray.BYTES_PER_ELEMENT 表示类型化数组的每个元素的大小(以字节为单位)。

句法

Atomics.isLockFree(size)

参数

  • 要检查的大小(以字节为单位)。

返回

如果操作是无锁的,则返回 true,否则返回 false。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - load() 方法

load方法返回数组中给定位置的值。

句法

Atomics.load(typedArray, index)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

返回

返回给定位置的值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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>

输出

验证结果。

Atomics - notify() 方法

notify方法通知等待的代理唤醒。通知方法仅适用于使用 SharedArrayBuffer 创建的 Int32Array。如果使用非共享 ArrayBuffer 对象,则返回 0。

句法

Atomics.notify(typedArray, index, count)

参数

  • typedArray是一个共享的 Int32Array。

  • 索引是类型数组中要唤醒的位置。

  • count是要通知的Hibernate代理的数量。

返回

返回被唤醒的代理数量。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - or() 方法

or方法使用数组中给定位置处的提供值计算按位或。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.or(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 要计算按位或的值。

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - store() 方法

store方法将一个值存储在数组中提供的位置并返回该值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.store(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中要存储值的位置。

  • 要存储的值。

返回

返回存储在给定位置的值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - sub() 方法

sub方法减去数组中给定位置处提供的值。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.sub(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 要减去的值。

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。

Atomics - xor() 方法

xor方法使用数组中给定位置处提供的值计算按位异或。它返回该位置的旧值。此Atomics操作可确保在写回修改的值之前不会发生其他写入。

句法

Atomics.xor(typedArray, index, value)

参数

  • typedArray是整数类型数组。

  • 索引是类型数组中的位置。

  • 要计算按位异或的值。

返回

返回给定位置的旧值。

例外情况

  • 如果传递的数组不是整数类型数组,则会出现TypeError 。

  • 如果传递的索引在类型化数组中超出范围,则出现RangeError 。

例子

以下是实现 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.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>

输出

验证结果。