Método AtomicLongArray getAndAccumulate() en Java con ejemplos

Java.util.concurrent.atomic.AtomicLongArray.getAndAccumulate () es un método incorporado en Java que actualiza atómicamente el valor en cualquier índice de AtomicLongArray con el resultado después de aplicar la función dada a los valores actuales y dados, devolviendo el valor anterior . Este método acepta como parámetro el índice del AtomicLongArray donde se va a realizar la operación, el valor con el que se realiza la operación y la función acumuladora. La función se aplica con el valor actual en el índice como primer argumento y la actualización dada como segundo argumento. La función del acumulador 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 getAndAccumulate() es similar aacumuleAndGet() pero la primera función devuelve el valor antes de la actualización, mientras que la última devuelve el valor después de la actualización.

Sintaxis:

public final long getAndAccumulate(int i, long 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 antes de la actualización que está en long .
    Los siguientes programas ilustran el método anterior:
    Programa 1:

    // Java program that demonstrates
    // the getAndAccumulate() 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 getAndAccumulate
            long prev = arr.getAndAccumulate(idx, x, add);
      
            // The previous value at idx
            System.out.println("Value at index " + idx
                               + " before update is "
                               + prev);
      
            // Displaying the AtomicLongArray
            System.out.println("The array after update : "
                               + arr);
        }
    }
    
    Producción:

    The array : [1, 2, 3, 4, 5]
    Value at index 4 before update is 5
    The array after update : [1, 2, 3, 4, 10]
    

    Programa 2:

    // Java program that demonstrates
    // the getAndAccumulate() 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 = 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 getAndAccumulate
            long prev = arr.getAndAccumulate(idx, x, sub);
      
            // The previous value at idx
            System.out.println("Value at index " + idx
                               + " before update is "
                               + prev);
      
            // Displaying the AtomicLongArray
            System.out.println("The array after update : "
                               + arr);
        }
    }
    
    Producción:

    The array : [1, 2, 3, 4, 5]
    Value at index 0 before update is 1
    The array after update : [-5, 2, 3, 4, 5]
    

    Referencia:
    https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicLongArray.html#getAndAccumulate-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 *