Java Concurrency - Kelas AtomicLongArray
Kelas java.util.concurrent.atomic.AtomicLongArray menyediakan operasi pada larik panjang yang mendasari yang dapat dibaca dan ditulis secara atomik, dan juga berisi operasi atom tingkat lanjut. AtomicLongArray mendukung operasi atom pada variabel array panjang yang mendasarinya. Ini telah mendapatkan dan menetapkan metode yang berfungsi seperti membaca dan menulis pada variabel volatil. Artinya, himpunan memiliki hubungan terjadi-sebelum dengan get berikutnya pada variabel yang sama. Metode atomic CompareAndSet juga memiliki fitur konsistensi memori ini.
Metode AtomicLongArray
Berikut adalah daftar metode penting yang tersedia di kelas AtomicLongArray.
Sr.No. | Metode & Deskripsi |
---|---|
1 | public long addAndGet(int i, long delta) Secara atomis menambahkan nilai yang diberikan ke elemen pada indeks i. |
2 | public boolean compareAndSet(int i, long expect, long update) Secara atomis menyetel elemen di posisi i ke nilai yang diperbarui jika nilai saat ini == nilai yang diharapkan. |
3 | public long decrementAndGet(int i) Secara atomis mengurangi satu elemen pada indeks i. |
4 | public long get(int i) Mendapat nilai saat ini pada posisi i. |
5 | public long getAndAdd(int i, long delta) Secara atomis menambahkan nilai yang diberikan ke elemen pada indeks i. |
6 | public long getAndDecrement(int i) Secara atomis mengurangi satu elemen pada indeks i. |
7 | public long getAndIncrement(int i) Secara atomis bertambah satu elemen pada indeks i. |
8 | public long getAndSet(int i, long newValue) Secara atomis menyetel elemen di posisi i ke nilai yang diberikan dan mengembalikan nilai lama. |
9 | public long incrementAndGet(int i) Secara atomis bertambah satu elemen pada indeks i. |
10 | public void lazySet(int i, long newValue) Akhirnya mengatur elemen di posisi i ke nilai yang diberikan. |
11 | public int length() Mengembalikan panjang larik. |
12 | public void set(int i, long newValue) Setel elemen di posisi i ke nilai yang diberikan. |
13 | public String toString() Mengembalikan representasi String dari nilai-nilai array saat ini. |
14 | public boolean weakCompareAndSet(int i, long expect, long update) Secara atomis menyetel elemen di posisi i ke nilai yang diperbarui jika nilai saat ini == nilai yang diharapkan. |
Contoh
Program TestThread berikut menunjukkan penggunaan variabel AtomicIntegerArray di lingkungan berbasis thread.
import java.util.concurrent.atomic.AtomicLongArray;
public class TestThread {
private static AtomicLongArray atomicLongArray = new AtomicLongArray(10);
public static void main(final String[] arguments) throws InterruptedException {
for (int i = 0; i<atomicLongArray.length(); i++) {
atomicLongArray.set(i, 1);
}
Thread t1 = new Thread(new Increment());
Thread t2 = new Thread(new Compare());
t1.start();
t2.start();
t1.join();
t2.join();
System.out.println("Values: ");
for (int i = 0; i<atomicLongArray.length(); i++) {
System.out.print(atomicLongArray.get(i) + " ");
}
}
static class Increment implements Runnable {
public void run() {
for(int i = 0; i<atomicLongArray.length(); i++) {
long add = atomicLongArray.incrementAndGet(i);
System.out.println("Thread " + Thread.currentThread().getId()
+ ", index " +i + ", value: "+ add);
}
}
}
static class Compare implements Runnable {
public void run() {
for(int i = 0; i<atomicLongArray.length(); i++) {
boolean swapped = atomicLongArray.compareAndSet(i, 2, 3);
if(swapped) {
System.out.println("Thread " + Thread.currentThread().getId()
+ ", index " +i + ", value: 3");
}
}
}
}
}
Ini akan menghasilkan hasil sebagai berikut.
Keluaran
Thread 9, index 0, value: 2
Thread 10, index 0, value: 3
Thread 9, index 1, value: 2
Thread 9, index 2, value: 2
Thread 9, index 3, value: 2
Thread 9, index 4, value: 2
Thread 10, index 1, value: 3
Thread 9, index 5, value: 2
Thread 10, index 2, value: 3
Thread 9, index 6, value: 2
Thread 10, index 3, value: 3
Thread 9, index 7, value: 2
Thread 10, index 4, value: 3
Thread 9, index 8, value: 2
Thread 9, index 9, value: 2
Thread 10, index 5, value: 3
Thread 10, index 6, value: 3
Thread 10, index 7, value: 3
Thread 10, index 8, value: 3
Thread 10, index 9, value: 3
Values:
3 3 3 3 3 3 3 3 3 3