java中的鎖是什么?很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
成都創(chuàng)新互聯(lián)專注于企業(yè)成都全網(wǎng)營銷推廣、網(wǎng)站重做改版、青陽網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5響應(yīng)式網(wǎng)站、購物商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為青陽等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
鎖是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ā)沖突,同步所有對數(shù)據(jù)的相關(guān)操作,從讀數(shù)據(jù)就開始上鎖
獨(dú)享鎖(寫) : 給資源加上寫鎖,擁有該鎖的線程可以修改資源,其他線程不能再加鎖(單寫)
共享鎖(讀) : 給資源加上讀鎖后只能讀不能改,其他線程也只能加讀鎖,不能加寫鎖 (多讀)
可重入鎖 :線程拿到一把鎖后,可以自由進(jìn)入同一把鎖所同步的代碼
不可重入鎖 :線程拿到一把鎖后,不可以自由進(jìn)入同一把鎖所同步的代碼
公平鎖 :爭搶鎖的順序,按照先來后到的順序
非公平鎖 :爭搶鎖的順序,不按照先來后到的順序
Java中幾種重要的鎖實(shí)現(xiàn)方式:synchronized, ReentrantLock, ReentrantReadWriteLock
同步關(guān)鍵字:synchronized
鎖的作用域:對象鎖,類鎖,分布式鎖
synchronized特性:可重入,獨(dú)享,悲觀鎖
鎖優(yōu)化:
鎖消除是發(fā)生在編譯器級別的一種鎖優(yōu)化方式,是指虛擬機(jī)即時(shí)編譯器在運(yùn)行時(shí),對一些代碼上要求同步,但是被檢測到不可能存在共享數(shù)據(jù)競爭的鎖進(jìn)行削除(開啟鎖消除的參數(shù):-xx:+DoEscapeAnalysis -XX:+EliminateLocks)
鎖粗化:是指有些情況下我們反而希望把很多次鎖的請求合并成一個(gè)請求,以降低短時(shí)間內(nèi)大量鎖請求、同步、釋放帶來的性能損耗
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)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。