gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網
最全最豐富的資訊網站

圖文詳解!java中鎖的整理總結

本篇文章給大家帶來了關于java的相關知識,其中主要介紹了關于鎖的相關內容,包括了樂觀鎖、悲觀鎖、獨占鎖、共享鎖等等,下面一起來看一下,希望對大家有幫助。

圖文詳解!java中鎖的整理總結

推薦學習:《java視頻教程》

樂觀鎖和悲觀鎖

悲觀鎖

悲觀鎖對應于生活中悲觀的人,悲觀的人總是想著事情往壞的方向發展。

舉個生活中的例子,假設廁所只有一個坑位了,悲觀鎖上廁所會第一時間把門反鎖上,這樣其他人上廁所只能在門外等候,這種狀態就是「阻塞」了。

回到代碼世界中,一個共享數據加了悲觀鎖,那線程每次想操作這個數據前都會假設其他線程也可能會操作這個數據,所以每次操作前都會上鎖,這樣其他線程想操作這個數據拿不到鎖只能阻塞了。

圖文詳解!java中鎖的整理總結

在 Java 語言中 synchronizedReentrantLock等就是典型的悲觀鎖,還有一些使用了 synchronized 關鍵字的容器類如 HashTable 等也是悲觀鎖的應用。

樂觀鎖

樂觀鎖 對應于生活中樂觀的人,樂觀的人總是想著事情往好的方向發展。

舉個生活中的例子,假設廁所只有一個坑位了,樂觀鎖認為:這荒郊野外的,又沒有什么人,不會有人搶我坑位的,每次關門上鎖多浪費時間,還是不加鎖好了。你看樂觀鎖就是天生樂觀!

回到代碼世界中,樂觀鎖操作數據時不會上鎖,在更新的時候會判斷一下在此期間是否有其他線程去更新這個數據。

圖文詳解!java中鎖的整理總結

樂觀鎖可以使用版本號機制CAS算法實現。在 Java 語言中 java.util.concurrent.atomic包下的原子類就是使用CAS 樂觀鎖實現的。

兩種鎖的使用場景

悲觀鎖和樂觀鎖沒有孰優孰劣,有其各自適應的場景。

樂觀鎖適用于寫比較少(沖突比較小)的場景,因為不用上鎖、釋放鎖,省去了鎖的開銷,從而提升了吞吐量。

如果是寫多讀少的場景,即沖突比較嚴重,線程間競爭激勵,使用樂觀鎖就是導致線程不斷進行重試,這樣可能還降低了性能,這種場景下使用悲觀鎖就比較合適。

獨占鎖和共享鎖

獨占鎖

獨占鎖是指鎖一次只能被一個線程所持有。如果一個線程對數據加上排他鎖后,那么其他線程不能再對該數據加任何類型的鎖。獲得獨占鎖的線程即能讀數據又能修改數據。

圖文詳解!java中鎖的整理總結

JDK中的synchronizedjava.util.concurrent(JUC)包中Lock的實現類就是獨占鎖。

共享鎖

共享鎖是指鎖可被多個線程所持有。如果一個線程對數據加上共享鎖后,那么其他線程只能對數據再加共享鎖,不能加獨占鎖。獲得共享鎖的線程只能讀數據,不能修改數據。

圖文詳解!java中鎖的整理總結

在 JDK 中 ReentrantReadWriteLock 就是一種共享鎖。

互斥鎖和讀寫鎖

互斥鎖

互斥鎖是獨占鎖的一種常規實現,是指某一資源同時只允許一個訪問者對其進行訪問,具有唯一性和排它性。

圖文詳解!java中鎖的整理總結

互斥鎖一次只能一個線程擁有互斥鎖,其他線程只有等待。

讀寫鎖

讀寫鎖是共享鎖的一種具體實現。讀寫鎖管理一組鎖,一個是只讀的鎖,一個是寫鎖。

讀鎖可以在沒有寫鎖的時候被多個線程同時持有,而寫鎖是獨占的。寫鎖的優先級要高于讀鎖,一個獲得了讀鎖的線程必須能看到前一個釋放的寫鎖所更新的內容。

讀寫鎖相比于互斥鎖并發程度更高,每次只有一個寫線程,但是同時可以有多個線程并發讀。

圖文詳解!java中鎖的整理總結

在 JDK 中定義了一個讀寫鎖的接口:ReadWriteLock

public interface ReadWriteLock {     /**      * 獲取讀鎖      */     Lock readLock();      /**      * 獲取寫鎖      */     Lock writeLock(); }

ReentrantReadWriteLock 實現了ReadWriteLock接口,具體實現這里不展開,后續會深入源碼解析。

公平鎖和非公平鎖

公平鎖

公平鎖是指多個線程按照申請鎖的順序來獲取鎖,這里類似排隊買票,先來的人先買,后來的人在隊尾排著,這是公平的。

圖文詳解!java中鎖的整理總結

在 java 中可以通過構造函數初始化公平鎖

/** * 創建一個可重入鎖,true 表示公平鎖,false 表示非公平鎖。默認非公平鎖 */ Lock lock = new ReentrantLock(true);

非公平鎖

非公平鎖是指多個線程獲取鎖的順序并不是按照申請鎖的順序,有可能后申請的線程比先申請的線程優先獲取鎖,在高并發環境下,有可能造成優先級翻轉,或者饑餓的狀態(某個線程一直得不到鎖)。

圖文詳解!java中鎖的整理總結

在 java 中 synchronized 關鍵字是非公平鎖,ReentrantLock默認也是非公平鎖。

/** * 創建一個可重入鎖,true 表示公平鎖,false 表示非公平鎖。默認非公平鎖 */ Lock lock = new ReentrantLock(false);

可重入鎖

可重入鎖又稱之為遞歸鎖,是指同一個線程在外層方法獲取了鎖,在進入內層方法會自動獲取鎖。

圖文詳解!java中鎖的整理總結

對于Java ReentrantLock而言, 他的名字就可以看出是一個可重入鎖。對于Synchronized而言,也是一個可重入鎖。

敲黑板:可重入鎖的一個好處是可一定程度避免死鎖。

以 synchronized 為例,看一下下面的代碼:

public synchronized void mehtodA() throws Exception{  // Do some magic tings  mehtodB(); }  public synchronized void mehtodB() throws Exception{  // Do some magic tings }

上面的代碼中 methodA 調用 methodB,如果一個線程調用methodA 已經獲取了鎖再去調用 methodB 就不需要再次獲取鎖了,這就是可重入鎖的特性。如果不是可重入鎖的話,mehtodB 可能不會被當前線程執行,可能造成死鎖。

自旋鎖

自旋鎖是指線程在沒有獲得鎖時不是被直接掛起,而是執行一個忙循環,這個忙循環就是所謂的自旋。

圖文詳解!java中鎖的整理總結

自旋鎖的目的是為了減少線程被掛起的幾率,因為線程的掛起和喚醒也都是耗資源的操作。

如果鎖被另一個線程占用的時間比較長,即使自旋了之后當前線程還是會被掛起,忙循環就會變成浪費系統資源的操作,反而降低了整體性能。因此自旋鎖是不適應鎖占用時間長的并發情況的。

在 Java 中,AtomicInteger 類有自旋的操作,我們看一下代碼:

public final int getAndAddInt(Object o, long offset, int delta) {     int v;     do {         v = getIntVolatile(o, offset);     } while (!compareAndSwapInt(o, offset, v, v + delta));     return v; }

CAS 操作如果失敗就會一直循環獲取當前 value 值然后重試。

另外自適應自旋鎖也需要了解一下。

在JDK1.6又引入了自適應自旋,這個就比較智能了,自旋時間不再固定,由前一次在同一個鎖上的自旋時間以及鎖的擁有者的狀態來決定。如果虛擬機認為這次自旋也很有可能再次成功那就會次序較多的時間,如果自旋很少成功,那以后可能就直接省略掉自旋過程,避免浪費處理器資源。

分段鎖

分段鎖 是一種鎖的設計,并不是具體的一種鎖。

分段鎖設計目的是將鎖的粒度進一步細化,當操作不需要更新整個數組的時候,就僅僅針對數組中的一項進行加鎖操作。

圖文詳解!java中鎖的整理總結

在 Java 語言中 CurrentHashMap 底層就用了分段鎖,使用Segment,就可以進行并發使用了。

鎖升級(無鎖|偏向鎖|輕量級鎖|重量級鎖)

JDK1.6 為了提升性能減少獲得鎖和釋放鎖所帶來的消耗,引入了4種鎖的狀態:無鎖偏向鎖輕量級鎖重量級鎖,它會隨著多線程的競爭情況逐漸升級,但不能降級。

無鎖

無鎖狀態其實就是上面講的樂觀鎖,這里不再贅述。

偏向鎖

Java偏向鎖(Biased Locking)是指它會偏向于第一個訪問鎖的線程,如果在運行過程中,只有一個線程訪問加鎖的資源,不存在多線程競爭的情況,那么線程是不需要重復獲取鎖的,這種情況下,就會給線程加一個偏向鎖。

偏向鎖的實現是通過控制對象Mark Word的標志位來實現的,如果當前是可偏向狀態,需要進一步判斷對象頭存儲的線程 ID 是否與當前線程 ID 一致,如果一致直接進入。

輕量級鎖

當線程競爭變得比較激烈時,偏向鎖就會升級為輕量級鎖,輕量級鎖認為雖然競爭是存在的,但是理想情況下競爭的程度很低,通過自旋方式等待上一個線程釋放鎖。

重量級鎖

如果線程并發進一步加劇,線程的自旋超過了一定次數,或者一個線程持有鎖,一個線程在自旋,又來了第三個線程訪問時(反正就是競爭繼續加大了),輕量級鎖就會膨脹為重量級鎖,重量級鎖會使除了此時擁有鎖的線程以外的線程都阻塞。

升級到重量級鎖其實就是互斥鎖了,一個線程拿到鎖,其余線程都會處于阻塞等待狀態。

在 Java 中,synchronized 關鍵字內部實現原理就是鎖升級的過程:無鎖 –> 偏向鎖 –> 輕量級鎖 –> 重量級鎖。這一過程在后續講解 synchronized 關鍵字的原理時會詳細介紹。

鎖優化技術(鎖粗化、鎖消除)

鎖粗化

鎖粗化就是將多個同步塊的數量減少,并將單個同步塊的作用范圍擴大,本質上就是將多次上鎖、解鎖的請求合并為一次同步請求。

舉個例子,一個循環體中有一個代碼同步塊,每次循環都會執行加鎖解鎖操作。

private static final Object LOCK = new Object();  for(int i = 0;i < 100; i++) {     synchronized(LOCK){         // do some magic things     } }

經過鎖粗化后就變成下面這個樣子了:

 synchronized(LOCK){      for(int i = 0;i < 100; i++) {         // do some magic things     } }

鎖消除

鎖消除是指虛擬機編譯器在運行時檢測到了共享數據沒有競爭的鎖,從而將這些鎖進行消除。

舉個例子讓大家更好理解。

public String test(String s1, String s2){     StringBuffer stringBuffer = new StringBuffer();     stringBuffer.append(s1);     stringBuffer.append(s2);     return stringBuffer.toString(); }

上面代碼中有一個 test 方法,主要作用是將字符串 s1 和字符串 s2 串聯起來。

test 方法中三個變量s1, s2, stringBuffer, 它們都是局部變量,局部變量是在棧上的,棧是線程私有的,所以就算有多個線程訪問 test 方法也是線程安全的。

我們都知道 StringBuffer 是線程安全的類,append 方法是同步方法,但是 test 方法本來就是線程安全的,為了提升效率,虛擬機幫我們消除了這些同步鎖,這個過程就被稱為鎖消除

StringBuffer.class  // append 是同步方法 public synchronized StringBuffer append(String str) {     toStringCache = null;     super.append(str);     return this; }

一張圖總結:

Java 并發編程的知識非常多,同時也是 Java 面試的高頻考點,面試官必問的,需要學習 Java 并發編程其他知識的小伙伴可以去下載『阿里師兄總結的Java知識筆記 總共 283 頁,超級詳細』。

前面講了 Java 語言中各種各種的鎖,最后再通過六個問題統一總結一下:

圖文詳解!java中鎖的整理總結

推薦學習:《java視頻教程》

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
国产精品免费观看久久| 8x8x最新地址| 成年人视频观看| 日本黄色三级大片| 亚洲老女人av| 日本一道在线观看| 韩国中文字幕av| 欧美日韩亚洲国产成人| 成人一区二区av| 亚洲高清在线免费观看| 久久久久久av无码免费网站下载| 中文字幕免费高| 欧美视频第三页| 欧美大片久久久| 88av.com| 一区二区三区国产免费| 亚洲 欧美 综合 另类 中字| 久久人妻精品白浆国产| 黄色一级大片免费| 午夜免费福利在线| 久久久久久久少妇| 少妇无码av无码专区在线观看| 中文字幕日韩综合| 日日干夜夜操s8| 91香蕉视频在线观看视频| 91淫黄看大片| 五月婷婷深爱五月| 色戒在线免费观看| 亚洲日本黄色片| 日韩a级黄色片| 久久网站免费视频| 可以免费观看av毛片| 亚洲色图 在线视频| 手机看片福利日韩| 久久天天东北熟女毛茸茸| 久久免费视频2| 国产 日韩 亚洲 欧美| 日韩av综合在线观看| 中文字幕永久视频| 国产内射老熟女aaaa| 久久久久免费精品| 无码人妻aⅴ一区二区三区日本| 日韩精品一区二区三区电影| 中国老女人av| 国产精品亚洲a| 久久人妻无码一区二区| 熟妇人妻va精品中文字幕| 操bbb操bbb| 五月婷婷六月丁香激情| 国产一区一区三区| 黄大色黄女片18第一次| 日韩日韩日韩日韩日韩| 超碰免费在线公开| 91极品尤物在线播放国产| www.亚洲视频.com| 色香蕉在线观看| 天天爱天天做天天操| 日韩爱爱小视频| 92看片淫黄大片一级| 欧美一级视频免费看| av电影一区二区三区| 日韩精品视频一二三| 性欧美极品xxxx欧美一区二区| 99热自拍偷拍| 婷婷五月综合缴情在线视频| 艳母动漫在线观看| 咪咪色在线视频| 亚洲精品中文字幕乱码无线| 亚洲一区二区蜜桃| 青青草原播放器| cao在线观看| 国产综合av在线| 色一情一区二区| 欧美大片久久久| 成年人视频观看| www.天天射.com| 日本一级淫片演员| 精品视频在线观看一区| 国产精品涩涩涩视频网站| 日韩精品视频网址| 国产免费成人在线| 国产欧美精品一二三| 人人妻人人澡人人爽欧美一区双 | 国产a级黄色大片| 日韩精品无码一区二区三区免费| 污视频网站观看| 丰满少妇久久久| 日本高清免费观看| 免费网站在线观看黄| 国产综合免费视频| 欧美视频在线观看视频| 日本免费色视频| caopor在线视频| 欧美久久久久久久久久久久久| 久久久福利影院| 日本在线播放一区二区| 国产淫片av片久久久久久| 性一交一乱一伧国产女士spa| 日日躁夜夜躁aaaabbbb| 久久久久久香蕉| 日韩一级理论片| 加勒比av中文字幕| 可以看污的网站| 51xx午夜影福利| 久青草视频在线播放| 久久艹国产精品| www.爱色av.com| 亚洲精品自拍网| 国产毛片久久久久久| 国产一二三四五| 午夜精品久久久久久久无码| 欧美啪啪免费视频| www.超碰97.com| 国产精品va在线观看无码| 欧美 日韩 激情| 久久精品视频在线观看免费| 日本免费a视频| 中文字幕久久av| 最新中文字幕2018| 黄色一级视频在线播放| 日本精品一区在线| 成人性做爰aaa片免费看不忠| 午夜激情在线观看视频| 无罩大乳的熟妇正在播放| 午夜xxxxx| 天天干天天综合| 欧美婷婷精品激情| 777米奇影视第四色| 亚洲精品无码国产| 特级毛片在线免费观看| 在线观看免费av网址| 亚洲人成色77777| 国产精品免费成人| 日韩在线第三页| www.久久av.com| 免费看av软件| 国产一级不卡视频| 妺妺窝人体色777777| 免费cad大片在线观看| 日本免费a视频| 99热在线这里只有精品| 久久综合久久色| 天堂视频免费看| 久久久久久av无码免费网站下载| 国产对白在线播放| 欧美精品一区免费| 亚洲制服中文字幕| 男女爱爱视频网站| 欧在线一二三四区| 三日本三级少妇三级99| 国内少妇毛片视频| 亚洲最大综合网| 亚洲熟妇无码一区二区三区| 成人久久久久久久久| 国产精品igao网网址不卡| 99热都是精品| 日本精品一区二区三区四区| 日韩视频在线观看视频| 免费看又黄又无码的网站| 天天爱天天做天天操| 黄色av网址在线播放| 91嫩草国产丨精品入口麻豆| 精品久久一二三| 你真棒插曲来救救我在线观看| 亚洲欧美偷拍另类| 草草久久久无码国产专区| 九九久久九九久久| 国产又黄又爽免费视频| 久久撸在线视频| 亚洲污视频在线观看| a级黄色一级片| av动漫在线看| 成人在线激情网| 日韩成人av免费| 二级片在线观看| 日韩极品视频在线观看| 日本精品免费视频| 99久久免费观看| 好男人www社区| 午夜免费福利网站| 欧美另类videosbestsex日本| 国产精品波多野结衣| 欧美成人精品免费| 午夜在线观看av| 国产精品视频网站在线观看| 超碰超碰超碰超碰超碰| 国产免费黄色av| 日本一区二区免费高清视频| av之家在线观看| 美国av在线播放| 日韩一区二区三区不卡视频| 日本成人xxx| 自拍偷拍21p| 国产h视频在线播放| 黄色片免费网址| 在线免费观看视频黄| 人人妻人人做人人爽| 国产精品波多野结衣| 免费国产成人av| www.xxx亚洲|