एटॉमिक्स - क्विक गाइड

एटोमिक्स

एटमिक्स जावास्क्रिप्ट में एक वस्तु है जो स्थैतिक विधियों के रूप में निष्पादित होने के लिए परमाणु संचालन प्रदान करती है। मैथ ऑब्जेक्ट के तरीकों की तरह, एटॉमिक्स के तरीके और गुण भी स्थिर हैं। एटमिक्स का उपयोग SharedArrayBuffer ऑब्जेक्ट के साथ किया जाता है।

परमाणु संचालन एक परमाणु मॉड्यूल पर स्थापित होते हैं। अन्य वैश्विक वस्तुओं के विपरीत, एटॉमिक्स एक निर्माता नहीं है। एटमिक्स का उपयोग नए ऑपरेटर के साथ नहीं किया जा सकता है या इसे फ़ंक्शन के रूप में लागू किया जा सकता है।

परमाणु संचालन

परमाणु संचालन अबाध है।

जब मेमोरी साझा की जाती है, तो कई थ्रेड्स मेमोरी में मौजूद डेटा को पढ़ या लिख ​​सकते हैं। इसलिए यदि कोई डेटा बदल गया है, तो डेटा की हानि होगी परमाणु संचालन सुनिश्चित करें कि अनुमानित मान (डेटा) सही ढंग से लिखे और पढ़े गए हैं। परमाणु संचालन तब तक शुरू नहीं होगा जब तक कि वर्तमान ऑपरेशन समाप्त नहीं हो जाता है, इसलिए किसी मौजूद डेटा को बदलने का कोई तरीका नहीं है।

उदाहरण

निम्नलिखित जावास्क्रिप्ट एटोमिक्स ऑपरेशन के उपयोग का कोड है -

<!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>

उत्पादन

परिणाम सत्यापित करें।

एटोमिक्स

एटमिक्स जावास्क्रिप्ट में एक वस्तु है जो स्थैतिक विधियों के रूप में निष्पादित होने के लिए परमाणु संचालन प्रदान करती है। मैथ ऑब्जेक्ट के तरीकों की तरह, एटॉमिक्स के तरीके और गुण भी स्थिर हैं। एटमिक्स का उपयोग SharedArrayBuffer ऑब्जेक्ट के साथ किया जाता है।

परमाणु संचालन एक परमाणु मॉड्यूल पर स्थापित होते हैं। अन्य वैश्विक वस्तुओं के विपरीत, एटॉमिक्स एक निर्माता नहीं है। एटमिक्स का उपयोग नए ऑपरेटर के साथ नहीं किया जा सकता है या इसे फ़ंक्शन के रूप में लागू किया जा सकता है।

परमाणु संचालन

परमाणु संचालन अबाध है।

जब मेमोरी साझा की जाती है, तो कई थ्रेड्स मेमोरी में मौजूद डेटा को पढ़ या लिख ​​सकते हैं। इसलिए यदि कोई डेटा बदल गया है, तो डेटा की हानि होगी परमाणु संचालन सुनिश्चित करें कि अनुमानित मान (डेटा) सही ढंग से लिखे और पढ़े गए हैं। परमाणु संचालन तब तक शुरू नहीं होगा जब तक कि वर्तमान ऑपरेशन समाप्त नहीं हो जाता है, इसलिए किसी मौजूद डेटा को बदलने का कोई तरीका नहीं है।

उदाहरण

निम्नलिखित जावास्क्रिप्ट एटोमिक्स ऑपरेशन के उपयोग का कोड है -

<!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 टाइपराइड में स्थिति है।

  • value जोड़ा जाएगा।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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विधि बिटवाइड और सरणी में दिए गए स्थान पर दिए गए मूल्य के साथ गणना करती है। यह उस स्थिति में पुराना मान लौटाता है। यह परमाणु संचालन सुनिश्चित करता है कि जब तक संशोधित मूल्य वापस नहीं लिखा जाता है तब तक कोई अन्य लेखन नहीं हो सकता है।

वाक्य - विन्यास

Atomics.and(typedArray, index, value)

मापदंडों

  • typedArray पूर्णांक टाइप किया गया सरणी है।

  • index टाइपराइड में स्थिति है।

  • value जिसके साथ बिटवाइस और गणना की जा सके।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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 टाइपराइड में स्थिति है।

  • expectedValue समानता के लिए जाँच करने के लिए।

  • replacementValue अदला बदली।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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 टाइपराइड में स्थिति है।

  • value अदला बदली।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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विधि का उपयोग यह निर्धारित करने के लिए किया जाता है कि परमाणु कार्यों के लिए ताले का उपयोग किया जाना है या नहीं। यदि दिया गया आकार पूर्णांक टाइप में से एक है। NYTES_PER_ELEMENT पूर्णांक प्रकार की संपत्ति टाइप की गई है तो यह सही है। TypedArray.BYTES_PER_ELEMENT टाइप किए गए सरणी के प्रत्येक तत्व के बाइट्स में आकार का प्रतिनिधित्व करता है।

वाक्य - विन्यास

Atomics.isLockFree(size)

मापदंडों

  • size बाइट्स में जांच की जाएगी।

वापसी

सही है अगर ऑपरेशन बंद है झूठे के रूप में मुक्त।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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 टाइपराइड में स्थिति है।

वापसी

दिए गए स्थान पर मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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विधि जागने के लिए प्रतीक्षा एजेंट को सूचित करती है। अधिसूचित विधि SharedArrayBuffer का उपयोग करके बनाई गई Int32Array के साथ ही काम कर सकती है। गैर-साझा किए गए ArrayBuffer ऑब्जेक्ट के उपयोग के मामले में यह 0 देता है।

वाक्य - विन्यास

Atomics.notify(typedArray, index, count)

मापदंडों

  • typedArray एक साझा Int32Array है।

  • index को जगाने के लिए टाइपराइडर में स्थिति है।

  • count सो रहे एजेंटों की संख्या को सूचित करना है।

वापसी

लौट आए एजेंटों की संख्या।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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विधि बिटवाइज या सरणी में दिए गए स्थान पर दिए गए मूल्य के साथ गणना करती है। यह उस स्थिति में पुराना मान लौटाता है। यह परमाणु संचालन सुनिश्चित करता है कि जब तक संशोधित मूल्य वापस नहीं लिखा जाता है तब तक कोई अन्य लेखन नहीं हो सकता है।

वाक्य - विन्यास

Atomics.or(typedArray, index, value)

मापदंडों

  • typedArray पूर्णांक टाइप किया गया सरणी है।

  • index टाइपराइड में स्थिति है।

  • value जिसके साथ बिटवाइस या गणना की जा सके।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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 टाइपराइडर में स्थिति है जहाँ मूल्य को संग्रहीत किया जाना है।

  • value भंडारण करने के लिए।

वापसी

दिए गए स्थान पर संग्रहीत मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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 टाइपराइड में स्थिति है।

  • value घटाया जाना।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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 टाइपराइड में स्थिति है।

  • value जिसके साथ बिटकॉइन XOR की गणना की जाए।

वापसी

दिए गए पद पर पुराना मान लौटाता है।

अपवाद

  • TypeError मामले में पारित सरणी एक पूर्णांक टाइप सरणी नहीं है।

  • RangeError यदि इंडेक्स पास किया गया है तो टाइप किए गए सरणी में बाध्य है।

उदाहरण

जावास्क्रिप्ट एटॉमिक्स को लागू करने के लिए कोड निम्नलिखित है -

<!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>

उत्पादन

परिणाम सत्यापित करें।