Rumah Java javaTutorial java多线程关键字volatile、lock以及synchronized的简单介绍

java多线程关键字volatile、lock以及synchronized的简单介绍

Sep 25, 2018 pm 03:36 PM
java multithreading

本篇文章给大家带来的内容是关于java多线程关键字volatile、lock以及synchronized的简单介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

一、volatile

volatile写和volatile读的内存语义:

  线程A写一个volatile变量,实质上是线程A向接下来将要读这个volatile变量的某个线程发出了(其对共享变量所在修改的)消息。 线程B读一个volatile变量,实质上是线程B接收了之前某个线程发出的(在写这个volatile变量之前对共享变量所做修改的)消息。 线程A写一个volatile变量,随后线程B读这个volatile变量,这个过程实质上是线程A通过主内存向线程B发送消息。

锁释放和锁获取的内存语义:

  线程A释放一个锁,实质上是线程A向接下来将要获取这个锁的某个线程发出了(线程A对共享变量所做修改的)消息。 线程B获取一个锁,实质上是线程B接收了之前某个线程发出的(在释放这个锁之前对共享变量所做修改的)消息。 线程A释放锁,随后线程B获取这个锁,这个过程实质上是线程A通过主内存向线程B发送消息。

   总结:volatile关键字的作用是:使变量在多个线程间可见(具有可见性),但是仅靠volatile是不能保证线程的安全性,volatile关键字不具备synchronized关键字的原子性。

二、lock

   Lock是一个接口:

public interface Lock {  
   void lock();     
   void lockInterruptibly() throws InterruptedException;
    boolean tryLock();
    boolean tryLock(long time, TimeUnit unit) throws InterruptedException;
    void unlock();
    Condition newCondition();
}
Salin selepas log masuk

lock()、tryLock()、tryLock(long time, TimeUnit unit)和lockInterruptibly()是用来获取锁的。

unLock()方法是用来释放锁的。 tryLock()方法是有返回值的,它表示用来尝试获取锁,如果获取成功,则返回true,如果获取失败(即锁已被其他线程获取),则返回false,也就说这个方法无论如何都会立即返回。在拿不到锁时不会一直在那等待。 tryLock(long time, TimeUnit unit)方法和tryLock()方法是类似的,只不过区别在于这个方法在拿不到锁时会等待一定的时间,在时间期限之内如果还拿不到锁,就返回false。如果如果一开始拿到锁或者在等待期间内拿到了锁,则返回true。 lockInterruptibly()方法比较特殊,当通过这个方法去获取锁时,如果线程正在等待获取锁,则这个线程能够响应中断,即中断线程的等待状态。也就使说,当两个线程同时通过lock.lockInterruptibly()想获取某个锁时,假若此时线程A获取到了锁,而线程B只有在等待,那么对线程B调用threadB.interrupt()方法能够中断线程B的等待过程。

lock在获取锁的过程可以被中断。 lock可以尝试获取锁,如果锁被其他线程持有,则返回 false,不会使当前线程休眠。 lock在尝试获取锁的时候,传入一个时间参数,如果在这个时间范围内,没有获得锁,那么就是终止请求。 synchronized 会自动释放锁,lock 则不会自动释放锁。 注:lock() 可以用于对一段代码进行加锁,这样别的代码在锁释放之前需要进行等待,需要注意,lock不会像 synchronized 那样自动释放锁,所以:一定要放在 try-finally块中,保证锁的释放。

Lock和synchronized有以下几点不同:

  1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现;

  2)synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock时需要在finally块中释放锁;

  3)Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;

  4)通过Lock可以知道有没有成功获取锁,而synchronized却无法办到。

  5)Lock可以提高多个线程进行读操作的效率。   在性能上来说,如果竞争资源不激烈,两者的性能是差不多的,而当竞争资源非常激烈时(即有大量线程同时竞争),此时Lock的性能要远远优于synchronized。所以说,在具体使用时要根据适当情况选择。 ReentrantLock,意思是“可重入锁”,关于可重入锁的概念在下一节讲述。ReentrantLock是唯一实现了Lock接口的类,并且ReentrantLock提供了更多的方法。

三、synchronized

     1、当两个并发线程访问同一个对象object中的这个synchronized(this)同步代码块时,一个时间内只能有一个线程得到执行。另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块。

     2、然而,当一个线程访问object的一个synchronized(this)同步代码块时,另一个线程仍然可以访问该object中的非synchronized(this)同步代码块。

     3、尤其关键的是,当一个线程访问object的一个synchronized(this)同步代码块时,其他线程对object中所有其它synchronized(this)同步代码块的访问将被阻塞。

     4、第三个例子同样适用其它同步代码块。也就是说,当一个线程访问object的一个synchronized(this)同步代码块时,它就获得了这个object的对象锁。结果,其它线程对该object对象所有同步代码部分的访问都被暂时阻塞。 synchronized关键字的作用域: 某个对象实例内,synchronized aMethod(){}可以防止多个线程同时访问这个对象的synchronized方法(如果一个对象有多个synchronized方法,只要一个线 程访问了其中的一个synchronized方法,其它线程不能同时访问这个对象中任何一个synchronized方法)。这时,不同的对象实例的 synchronized方法是不相干扰的。也就是说,其它线程照样可以同时访问相同类的另一个对象实例中的synchronized方法; 某个类的范围,synchronized static aStaticMethod{}防止多个线程同时访问这个类中的synchronized static 方法。它可以对类的所有对象实例起作用。

Atas ialah kandungan terperinci java多线程关键字volatile、lock以及synchronized的简单介绍. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penjelasan terperinci tentang senario penggunaan dan fungsi kata kunci yang tidak menentu dalam Java Penjelasan terperinci tentang senario penggunaan dan fungsi kata kunci yang tidak menentu dalam Java Jan 30, 2024 am 10:01 AM

Penjelasan terperinci tentang peranan dan senario aplikasi kata kunci yang tidak menentu dalam Java 1. Peranan kata kunci yang tidak menentu Dalam Java, kata kunci yang tidak menentu digunakan untuk mengenal pasti pembolehubah yang boleh dilihat di antara beberapa utas, iaitu, untuk memastikan keterlihatan. Khususnya, apabila pembolehubah diisytiharkan tidak menentu, sebarang pengubahsuaian pada pembolehubah itu akan diketahui dengan serta-merta oleh rangkaian lain. 2. Senario Aplikasi Bendera Status Kata Kunci Meruap Kata kunci tidak menentu sesuai untuk beberapa senario bendera status, seperti

Kaedah pengoptimuman pembangunan Java untuk prestasi pecutan berbilang benang membaca fail Kaedah pengoptimuman pembangunan Java untuk prestasi pecutan berbilang benang membaca fail Jun 30, 2023 pm 10:54 PM

Dalam pembangunan Java, membaca fail adalah operasi yang sangat biasa dan penting. Apabila perniagaan anda berkembang, begitu juga saiz dan bilangan fail. Untuk meningkatkan kelajuan membaca fail, kita boleh menggunakan multi-threading untuk membaca fail secara selari. Artikel ini akan memperkenalkan cara mengoptimumkan prestasi pecutan berbilang benang membaca fail dalam pembangunan Java. Pertama, sebelum membaca fail, kita perlu menentukan saiz dan kuantiti fail. Bergantung pada saiz dan bilangan fail, kami boleh menetapkan bilangan utas dengan munasabah. Bilangan benang yang berlebihan boleh mengakibatkan sumber terbuang,

Pengendalian pengecualian dalam persekitaran berbilang benang Java Pengendalian pengecualian dalam persekitaran berbilang benang Java May 01, 2024 pm 06:45 PM

Perkara utama pengendalian pengecualian dalam persekitaran berbilang benang: Pengecualian menangkap: Setiap utas menggunakan blok cuba-tangkap untuk menangkap pengecualian. Kendalikan pengecualian: cetak maklumat ralat atau lakukan logik pengendalian ralat dalam blok tangkapan. Tamatkan utas: Apabila pemulihan adalah mustahil, panggil Thread.stop() untuk menamatkan utas. UncaughtExceptionHandler: Untuk mengendalikan pengecualian yang tidak ditangkap, anda perlu melaksanakan antara muka ini dan menetapkannya pada urutan. Kes praktikal: pengendalian pengecualian dalam kumpulan benang, menggunakan UncaughtExceptionHandler untuk mengendalikan pengecualian yang tidak ditangkap.

Terokai prinsip kerja dan ciri java multithreading Terokai prinsip kerja dan ciri java multithreading Feb 21, 2024 pm 03:39 PM

Terokai prinsip kerja dan ciri Java multithreading Pengenalan: Dalam sistem komputer moden, multithreading telah menjadi kaedah biasa pemprosesan serentak. Sebagai bahasa pengaturcaraan yang berkuasa, Java menyediakan mekanisme multi-threading yang kaya, membolehkan pengaturcara menggunakan pemproses berbilang teras komputer dengan lebih baik dan meningkatkan kecekapan menjalankan program. Artikel ini akan meneroka prinsip kerja dan ciri-ciri berbilang benang Java dan menggambarkannya dengan contoh kod khusus. 1. Konsep asas multi-threading Multi-threading merujuk kepada melaksanakan berbilang thread pada masa yang sama dalam program, dan setiap thread memproses berbeza

Panduan Pengoptimuman Prestasi Java Multithreading Panduan Pengoptimuman Prestasi Java Multithreading Apr 11, 2024 am 11:36 AM

Panduan Pengoptimuman Prestasi Berbilang Benang Java menyediakan lima titik pengoptimuman utama: Kurangkan penciptaan benang dan overhed pemusnahan Elakkan pertikaian kunci yang tidak sesuai Gunakan struktur data tidak menyekat Leverage Berlaku-Sebelum perhubungan Pertimbangkan algoritma selari tanpa kunci

Teknologi penyahpepijatan berbilang benang Java didedahkan Teknologi penyahpepijatan berbilang benang Java didedahkan Apr 12, 2024 am 08:15 AM

Jawapan teknologi penyahpepijatan berbilang benang: 1. Cabaran dalam penyahpepijatan kod berbilang benang: Interaksi antara utas membawa kepada tingkah laku yang kompleks dan sukar untuk dikesan. 2. Teknologi penyahpepijatan berbilang benang Java: pembuangan benang penyahpepijatan baris demi baris (jstack) pantau kemasukan dan keluar acara pembolehubah setempat 3. Kes praktikal: gunakan pembuangan benang untuk mencari jalan buntu, gunakan peristiwa monitor untuk menentukan punca kebuntuan. 4. Kesimpulan: Teknologi penyahpepijatan berbilang benang yang disediakan oleh Java boleh menyelesaikan masalah yang berkaitan dengan keselamatan benang, kebuntuan dan perbalahan dengan berkesan.

Isu keselamatan berbilang benang dalam Java - penyelesaian kepada java.lang.ThreadDeath Isu keselamatan berbilang benang dalam Java - penyelesaian kepada java.lang.ThreadDeath Jun 25, 2023 am 11:22 AM

Java ialah bahasa pengaturcaraan yang digunakan secara meluas dalam pembangunan perisian moden, dan keupayaan pengaturcaraan berbilang benangnya juga merupakan salah satu kelebihan terbesarnya. Walau bagaimanapun, disebabkan masalah akses serentak yang disebabkan oleh berbilang benang, isu keselamatan berbilang benang sering berlaku di Jawa. Antaranya, java.lang.ThreadDeath ialah isu keselamatan berbilang benang biasa. Artikel ini akan memperkenalkan punca dan penyelesaian java.lang.ThreadDeath. 1. Sebab untuk java.lang.ThreadDeath

Penjelasan terperinci tentang kunci serentak berbilang benang Java Penjelasan terperinci tentang kunci serentak berbilang benang Java Apr 11, 2024 pm 04:21 PM

Mekanisme kunci konkurensi Java memastikan sumber yang dikongsi diakses oleh hanya satu utas dalam persekitaran berbilang benang. Jenisnya termasuk penguncian pesimis (peroleh kunci dan kemudian akses) dan penguncian optimistik (semak konflik selepas mengakses). Java menyediakan kelas kunci konkurensi terbina dalam seperti ReentrantLock (kunci mutex), Semaphore (semaphore) dan ReadWriteLock (kunci baca-tulis). Menggunakan kunci ini boleh memastikan akses selamat benang kepada sumber yang dikongsi, seperti memastikan bahawa apabila berbilang rangkaian mengakses pembilang pembolehubah dikongsi pada masa yang sama, hanya satu utas mengemas kini nilainya.

See all articles