Método AtomicLongArrayacumularAndGet() en Java con ejemplos

Java.util.concurrent.atomic.AtomicLongArray.accumulateAndGet () es un método incorporado en Java que actualiza atómicamente el elemento en el índice i con los resultados de aplicar la función dada a los valores actuales y dados, devolviendo el valor actualizado. La función no debe tener efectos secundarios, ya que se puede volver a aplicar cuando fallan los intentos de actualización debido a la contención entre subprocesos. La función se aplica con el valor actual en el índice i como primer argumento y la actualización dada como segundo argumento.

Sintaxis:

público final largo acumular y obtener (int i, largo x, LongBinaryOperator accumulatorFunction)

Parámetros: La función acepta tres parámetros:

  • i – El índice donde se realizará la actualización.
  • x – El valor para hacer la operación con valor en i
  • accumulatorFunction : una función sin efectos secundarios de dos argumentos.
  • Valor devuelto: la función devuelve el valor actualizado que está en long .

    Los siguientes programas ilustran el método anterior:
    Programa 1:

    // Java program that demonstrates
    // the accumulateAndGet() function
      
    import java.util.concurrent.atomic.AtomicLongArray;
    import java.util.function.LongBinaryOperator;
      
    public class GFG {
        public static void main(String args[])
        {
            // Initializing an array
            long a[] = { 1, 2, 3, 4, 5 };
      
            // Initializing an AtomicLongArray with array a
            AtomicLongArray arr = new AtomicLongArray(a);
      
            // Displaying the AtomicLongArray
            System.out.println("The array : " + arr);
      
            // Index where update is to be made
            int idx = 4;
      
            // Value to make operation with value at idx
            long x = 5;
      
            // Declaring the accumulatorFunction
            LongBinaryOperator add = (u, v) -> u + v;
      
            // Updating the value at idx
            // applying accumulatorFunction
            arr.accumulateAndGet(idx, x, add);
      
            // Displaying the AtomicLongArray
            System.out.println("The array after update : "
                               + arr);
        }
    }
    
    Producción:

    The array : [1, 2, 3, 4, 5]
    The array after update : [1, 2, 3, 4, 10]
    

    Programa 2:

    // Java program that demonstrates
    // the accumulateAndGet() function
      
    import java.util.concurrent.atomic.AtomicLongArray;
    import java.util.function.LongBinaryOperator;
      
    public class GFG {
        public static void main(String args[])
        {
            // Initializing an array
            long a[] = { 17, 22, 33, 44, 55 };
      
            // Initializing an AtomicLongArray with array a
            AtomicLongArray arr = new AtomicLongArray(a);
      
            // Displaying the AtomicLongArray
            System.out.println("The array : " + arr);
      
            // Index where update is to be made
            int idx = 0;
      
            // Value to make operation with value at idx
            long x = 6;
      
            // Declaring the accumulatorFunction
            LongBinaryOperator sub = (u, v) -> u - v;
      
            // Updating the value at idx
            // applying accumulatorFunction
            arr.accumulateAndGet(idx, x, sub);
      
            // Displaying the AtomicLongArray
            System.out.println("The array after update : "
                               + arr);
        }
    }
    
    Producción:

    The array : [17, 22, 33, 44, 55]
    The array after update : [11, 22, 33, 44, 55]
    

    Referencia:
    https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicLongArray.html#accumulateAndGet-int-long-java.util.function.LongBinaryOperator-

    Publicación traducida automáticamente

    Artículo escrito por rupesh_rao y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

    Deja una respuesta

    Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *