Atomics - metodo isLockFree ()

isLockFreeviene utilizzato per determinare se i blocchi devono essere utilizzati o meno per le operazioni atomiche. Se la dimensione specificata è una delle proprietà TypedArray.BYTES_PER_ELEMENT dei tipi TypedArray interi, restituisce true. TypedArray.BYTES_PER_ELEMENT rappresenta la dimensione in byte di ogni elemento di un array tipizzato.

Sintassi

Atomics.isLockFree(size)

Parametri

  • size da archiviare in byte.

Ritorno

Restituisce true se l'operazione è priva di blocchi come false.

Esempio

Di seguito è riportato il codice per l'implementazione di 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>

Produzione

Verifica il risultato.