Artikel ini membawakan anda isu berkaitan java, yang terutamanya memperkenalkan isu berkaitan CAS, CAS (bandingkan dan tukar), bandingkan dan tukar, yang boleh menyelesaikan situasi selari berbilang benang Berikut ialah mekanisme untuk kehilangan prestasi yang disebabkan oleh penggunaan kunci saya harap ia akan membantu semua orang.
Pembelajaran yang disyorkan: "tutorial java"
CAS (bandingkan dan tukar), Bandingkan dan tukar. Mekanisme yang boleh menyelesaikan kehilangan prestasi yang disebabkan oleh menggunakan kunci dalam situasi selari berbilang benang Operasi CAS mengandungi tiga operan—lokasi memori (V), nilai asal yang dijangkakan (A) dan nilai baharu (B). Jika nilai lokasi memori sepadan dengan nilai asal yang dijangkakan, pemproses secara automatik mengemas kini lokasi kepada nilai baharu. Jika tidak, pemproses tidak melakukan apa-apa. A thread mendapat nilai num daripada memori utama dan beroperasi pada num Apabila menulis nilai, thread akan membandingkan nilai num pertama yang diperolehi dengan nilai num dalam ingatan utama ditulis ke dalam ingatan utama Jika mereka tidak sama, perbandingan akan digelung sehingga berjaya.
Kata kunci yang tidak menentu sering digunakan apabila mengubah suai pembolehubah yang dikongsi, tetapi nilai yang tidak menentu mempunyai keterlihatan dan melarang penangkapan semula arahan (ketertiban), dan atomicity tidak boleh dijamin. Walaupun tiada masalah dalam satu benang, pelbagai masalah akan berlaku dalam berbilang benang, menyebabkan fenomena tidak selamat di tapak. Oleh itu, CAS dihasilkan selepas jdk1.5 dan menggunakan primitif CPU (tidak boleh dibahagikan, berterusan dan tidak terganggu) untuk memastikan keatoman operasi di tapak.
Java.util.concurrent (JUC) baharu dalam JDK1.5 dibina pada CAS. Berbanding dengan mekanisme kunci yang disegerakkan, CAS ialah pelaksanaan biasa bagi algoritma tidak menyekat. Oleh itu, JUC telah banyak meningkatkan prestasinya.
Contohnya, kelas AtomicInteger, AtomicInteger selamat untuk benang, berikut ialah kod sumber
Masuktidak selamatLihat buat sambil gelung diri, gelung diri di sini ada dalam Nilai nilai asal yang dijangkakan Jika ia tidak sepadan dengan nilai asal, ia akan mengitar semula nilai asal dan melalui CAS proses sehingga dapat Nilai baharu telah berjaya diberikan.
CAS ialah idea penguncian optimistik, dan kunci optimistik ringan tanpa penyekat merujuk kepada kegagalan utas atau Penggantungan tidak boleh menjejaskan kegagalan atau penggantungan algoritma benang lain.
Selesaikan masalah ABA (jika anda mempertimbangkan pengakhirannya, anda boleh mengabaikan masalah jika anda tidak mempertimbangkan prosesnya)
Bermula dari Java1.5, pakej atom JDK menyediakan kelas AtomicStampedReference untuk menyelesaikan masalah ABA . Kaedah compareAndSet bagi kelas ini adalah untuk memeriksa dahulu sama ada rujukan semasa adalah sama dengan rujukan yang dijangkakan dan sama ada bendera semasa adalah sama dengan bendera yang dijangkakan Jika semuanya sama, maka secara atom tetapkan nilai rujukan dan bendera kepada nilai kemas kini yang diberikan.
Pembelajaran yang disyorkan: " tutorial pembelajaran java"
Atas ialah kandungan terperinci Ketahui lebih lanjut mengenai CAS dalam java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!