Di Java, pakej java.util.concurrent.atomic menawarkan satu set kelas yang menyokong pengaturcaraan selamat benang tanpa kunci pada pembolehubah tunggal. Kelas-kelas ini secara kolektif dirujuk sebagai pembolehubah atom. Kelas atom yang paling biasa digunakan termasuk AtomicInteger , AtomicLong , AtomicBoolean dan AtomicReference.
Pembolehubah atom direka bentuk untuk dikemas kini secara atom, bermakna operasinya (seperti menambah, mengecil atau membandingkan dan menetapkan nilai) dilakukan sebagai satu langkah yang tidak boleh dibahagikan. Ini memastikan bahawa tiada utas lain boleh melihat pembolehubah dalam keadaan pertengahan.
Contoh: Menggunakan AtomicInteger
import java.util.concurrent.atomic.AtomicInteger; public class AtomicExample { private AtomicInteger counter = new AtomicInteger(0); public void incrementCounter() { counter.incrementAndGet(); } public int getCounter() { return counter.get(); } public static void main(String[] args) { AtomicExample example = new AtomicExample(); for (int i = 0; i < 100; i++) { new Thread(example::incrementCounter).start(); } // Add some delay to ensure all threads complete try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Final Counter Value: " + example.getCounter()); } }
Dalam contoh ini, AtomicInteger digunakan untuk mengekalkan pembilang yang boleh ditambah dengan selamat oleh berbilang urutan tanpa menyebabkan ketidakkonsistenan.
Istilah "atomicity" merujuk kepada operasi yang diselesaikan dalam satu langkah tanpa kemungkinan gangguan daripada operasi lain. Dalam konteks multithreading, ini bermakna kemas kini pembolehubah berlaku sebagai operasi semua-atau-tiada. Dengan jenis primitif biasa, operasi seperti kenaikan (i++) bukan atom, bermakna jika berbilang rangkaian cuba mengemas kini pembolehubah yang sama secara serentak, rasuah data boleh berlaku.
Contoh: Operasi Bukan Atom dengan Jenis Primitif
public class NonAtomicExample { private int counter = 0; public synchronized void incrementCounter() { counter++; } public int getCounter() { return counter; } public static void main(String[] args) { NonAtomicExample example = new NonAtomicExample(); for (int i = 0; i < 100; i++) { new Thread(example::incrementCounter).start(); } // Add some delay to ensure all threads complete try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Final Counter Value: " + example.getCounter()); } }
Walaupun penyegerakan digunakan, pendekatan ini boleh menyebabkan kesesakan prestasi disebabkan perbalahan benang. Kelas atom, bagaimanapun, mengelakkan ini dengan menggunakan arahan CPU peringkat rendah untuk memastikan atomicity tanpa mengunci.
Sekarang kita memahami apa itu pembolehubah atom dan cara ia berfungsi, mari kita terokai cara ia berbeza daripada jenis primitif biasa dari segi keatoman dan keselamatan benang.
Primitif biasa seperti int , panjang , boolean , dsb., bukan bersifat atom. Operasi pada pembolehubah ini, seperti menambah atau menetapkan nilai, boleh diganggu oleh urutan lain, yang membawa kepada data yang tidak konsisten atau rosak. Sebaliknya, pembolehubah atom memastikan bahawa operasi ini dilakukan sebagai satu langkah tanpa gangguan.
Contoh: Keadaan Perlumbaan dengan Jenis Primitif
public class RaceConditionExample { private int counter = 0; public void incrementCounter() { counter++; } public static void main(String[] args) { RaceConditionExample example = new RaceConditionExample(); for (int i = 0; i < 1000; i++) { new Thread(example::incrementCounter).start(); } try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Final Counter Value: " + example.counter); } }
Dalam contoh ini, nilai pembilang akhir mungkin bukan 1000 disebabkan keadaan perlumbaan. Berbilang benang boleh mengakses dan mengubah suai kaunter secara serentak, membawa kepada hasil yang tidak dapat diramalkan.
Keselamatan benang adalah pertimbangan utama dalam pengaturcaraan serentak. Primitif biasa memerlukan penyegerakan yang jelas supaya selamat untuk benang, yang boleh menyusahkan dan terdedah kepada ralat. Atomics, bagaimanapun, sememangnya selamat untuk benang, kerana ia menyediakan operasi atom terbina dalam.
Pertimbangan Prestasi
Menggunakan penyegerakan dengan primitif biasa boleh menyebabkan kesesakan prestasi disebabkan oleh overhed untuk memperoleh dan melepaskan kunci. Sebaliknya, kelas atom menyediakan penyelesaian yang lebih cekap dengan menggunakan algoritma bukan penyekat untuk mencapai keselamatan benang tanpa kunci.
Pembolehubah atom dalam Java menyediakan cara yang berkuasa dan cekap untuk mengendalikan konkurensi dan memastikan ketekalan data. Mereka berbeza dengan ketara daripada jenis primitif biasa dari segi atomicity dan keselamatan benang, menawarkan penyelesaian yang lebih berprestasi dalam persekitaran berbilang benang.
Dengan memahami konsep atom, anda boleh menulis kod serentak yang lebih selamat dan cekap dalam Java. Jika anda mempunyai sebarang pertanyaan atau memerlukan penjelasan lanjut, sila tinggalkan komen di bawah!
Baca siaran lebih lanjut di : Apakah itu Atom di Jawa? Memahami Atomicity dan Keselamatan Benang di Java
Atas ialah kandungan terperinci Apakah Atom di Jawa? Memahami Atomicity dan Keselamatan Benang di Jawa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!