The Java.util.concurrent.atomic.AtomicIntegerArray.compareAndSet() is an inbuilt method in java that atomically sets the element at a position to the given updated value if the current value is equal to the expected value. This method takes the index value, the expected value and the update value as the parameters and returns a boolean value stating if the value has been updated.
Syntax:
public final boolean compareAndSet(int i, int expect, int update)
Parameters: The function accepts three parameters:
- i: The index where operation is to be made.
- expect: The expected value to check if it is equal to current value.
- update: The value to be updated.
Return value: The function returns a boolean value stating if the value has been updated. It returns true if successful, else it returns false indicating that the current value was not equal to the expected value.
Below programs illustrate the above method:
Program 1:
// Java program that demonstrates // the compareAndSet() function import java.util.concurrent.atomic.AtomicIntegerArray; public class GFG { public static void main(String args[]) { // Initializing an array int a[] = { 1 , 2 , 3 , 4 , 5 }; // Initializing an AtomicIntegerArray with array a AtomicIntegerArray arr = new AtomicIntegerArray(a); // Displaying the AtomicIntegerArray System.out.println( "The array : " + arr); // Index where operation is performed int idx = 3 ; // Value to expect at idx int expect = 4 ; // Value to update if current value // is equal to expected value int update = 40 ; // Updating the value at idx // applying compareAndSet arr.compareAndSet(idx, expect, update); // Displaying the AtomicIntegerArray System.out.println( "The array after update : " + arr); } } |
The array : [1, 2, 3, 4, 5] The array after update : [1, 2, 3, 40, 5]
Program 2:
// Java program that demonstrates // the compareAndSet() function import java.util.concurrent.atomic.AtomicIntegerArray; public class GFG { public static void main(String args[]) { // Initializing an array int a[] = { 1 , 2 , 3 , 4 , 5 }; // Initializing an AtomicIntegerArray with array a AtomicIntegerArray arr = new AtomicIntegerArray(a); // Displaying the AtomicIntegerArray System.out.println( "The array : " + arr); // Index where operation is performed int idx = 3 ; // Value to expect at idx int expect = 40 ; // Value to update if current value // is equal to expected value int update = 4 ; // Updating the value at // idx applying compareAndSet arr.compareAndSet(idx, expect, update); // Displaying the AtomicIntegerArray System.out.println( "The array after update : " + arr); } } |
The array : [1, 2, 3, 4, 5] The array after update : [1, 2, 3, 4, 5]
Reference: The Java.util.concurrent.atomic.AtomicIntegerArray.compareAndSet() is an inbuilt method in java that atomically sets the element at a position to the given updated value if the current value is equal to the expected value. This method takes the index value, the expected value and the update value as the parameters and returns a boolean value stating if the value has been updated.
Syntax:
public final boolean compareAndSet(int i, Integer expect, Integer update)
Parameters: The function accepts three parameters:
Return value: The function returns a boolean value stating if the value has been updated. It returns true if successful, else it returns false indicating that the current value was not equal to the expected value.
Below programs illustrate the above method:
Program 1:
// Java program that demonstrates // the compareAndSet() function import java.util.concurrent.atomic.AtomicIntegerArray; public class GFG { public static void main(String args[]) { // Initializing an array Integer a[] = { 1 , 2 , 3 , 4 , 5 }; // Initializing an AtomicIntegerArray with array a AtomicIntegerArray arr = new AtomicIntegerArray(a); // Displaying the AtomicIntegerArray System.out.println( "The array : " + arr); // Index where operation is performed int idx = 3 ; // Value to expect at idx Integer expect = 4 ; // Value to update if current value // is equal to expected value Integer update = 40 ; // Updating the value at idx // applying compareAndSet arr.compareAndSet(idx, expect, update); // Displaying the AtomicIntegerArray System.out.println( "The array after update : " + arr); } } |
The array : [1, 2, 3, 4, 5] The array after update : [1, 2, 3, 40, 5]
Program 2:
// Java program that demonstrates // the compareAndSet() function import java.util.concurrent.atomic.AtomicIntegerArray; public class GFG { public static void main(String args[]) { // Initializing an array Integer a[] = { 1 , 2 , 3 , 4 , 5 }; // Initializing an AtomicIntegerArray with array a AtomicIntegerArray arr = new AtomicIntegerArray(a); // Displaying the AtomicIntegerArray System.out.println( "The array : " + arr); // Index where operation is performed int idx = 3 ; // Value to expect at idx Integer expect = 40 ; // Value to update if current value // is equal to expected value Integer update = 4 ; // Updating the value at // idx applying compareAndSet arr.compareAndSet(idx, expect, update); // Displaying the AtomicIntegerArray System.out.println( "The array after update : " + arr); } } |
The array : [1, 2, 3, 4, 5] The array after update : [1, 2, 3, 4, 5]