您好,登錄后才能下訂單哦!
java中的鎖是什么?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
鎖是java并發(fā)編程中最重要的同步機(jī)制。JAVA中實(shí)現(xiàn)加鎖是通過Synchronized關(guān)鍵字以及java.util.concurrent包下的相關(guān)類。
Java中鎖的概念
自旋鎖 : 是指當(dāng)一個(gè)線程在獲取鎖的時(shí)候,如果鎖已經(jīng)被其他線程獲取,那么該線程將循環(huán)等待,然后不斷判斷鎖是否能夠被成功獲取,直到獲取到鎖才會(huì)退出循環(huán)。
樂觀鎖 : 假定沒有沖突,在修改數(shù)據(jù)時(shí)如果發(fā)現(xiàn)數(shù)據(jù)和之前獲取的不一致,則讀最新數(shù)據(jù),修改后重試修改
悲觀鎖 :假定會(huì)發(fā)生并發(fā)沖突,同步所有對(duì)數(shù)據(jù)的相關(guān)操作,從讀數(shù)據(jù)就開始上鎖
獨(dú)享鎖(寫) : 給資源加上寫鎖,擁有該鎖的線程可以修改資源,其他線程不能再加鎖(單寫)
共享鎖(讀) : 給資源加上讀鎖后只能讀不能改,其他線程也只能加讀鎖,不能加寫鎖 (多讀)
可重入鎖 :線程拿到一把鎖后,可以自由進(jìn)入同一把鎖所同步的代碼
不可重入鎖 :線程拿到一把鎖后,不可以自由進(jìn)入同一把鎖所同步的代碼
公平鎖 :爭(zhēng)搶鎖的順序,按照先來后到的順序
非公平鎖 :爭(zhēng)搶鎖的順序,不按照先來后到的順序
Java中幾種重要的鎖實(shí)現(xiàn)方式:synchronized, ReentrantLock, ReentrantReadWriteLock
同步關(guān)鍵字:synchronized
鎖的作用域:對(duì)象鎖,類鎖,分布式鎖
synchronized特性:可重入,獨(dú)享,悲觀鎖
鎖優(yōu)化:
鎖消除是發(fā)生在編譯器級(jí)別的一種鎖優(yōu)化方式,是指虛擬機(jī)即時(shí)編譯器在運(yùn)行時(shí),對(duì)一些代碼上要求同步,但是被檢測(cè)到不可能存在共享數(shù)據(jù)競(jìng)爭(zhēng)的鎖進(jìn)行削除(開啟鎖消除的參數(shù):-xx:+DoEscapeAnalysis -XX:+EliminateLocks)
鎖粗化:是指有些情況下我們反而希望把很多次鎖的請(qǐng)求合并成一個(gè)請(qǐng)求,以降低短時(shí)間內(nèi)大量鎖請(qǐng)求、同步、釋放帶來的性能損耗
Note: synchronized關(guān)鍵字,不僅實(shí)現(xiàn)同步,JMM中規(guī)定,synchronized要保證可見性(不能夠被緩存)
synchronized用法代碼示例:
public class Counter { private static int i = 0; // 等價(jià)于 synchronized(this) public synchronized void update() { i++; } public void updateBlock() { synchronized (this) { i++; } } // 等價(jià)于 synchronized (Counter.class) public static synchronized void staticUpdate() { i++; } public static void staticUpdateBlock() { synchronized (Counter.class) { i++; } } }
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。