日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

三道java新手入門面試題,通往自由的道路--鎖+Volatile

瀏覽:38日期:2022-08-10 16:21:37
目錄1. 你知道volatile是如何保證可見性嗎?小結:2. 悲觀鎖和樂觀鎖可以講下你的理解嗎?3. 你還知道什么其他的鎖嗎?總結1. 你知道volatile是如何保證可見性嗎?

我們先看一組代碼:

public class VolatileVisibleDemo { public static boolean initFlag = false; public static void main(String[] args) {new Thread(new Runnable() { @Override public void run() {System.out.println('等待initFlag改變!!!');// 如果initFlag發(fā)生改變了,這是為true的話,才會結束循環(huán)while(!initFlag) {}System.out.println('今天的世界打烊了,晚安!'); }}).start();// 這里是為了能保證運行完上面的代碼try { Thread.sleep(1000);} catch (InterruptedException e) { e.printStackTrace();}// 這里是Lambda表達式,就是上面的縮寫new Thread(() -> { System.out.println('準備填充數(shù)據(jù),修改initFlag的值'); initFlag = true; System.out.println('準備數(shù)據(jù)完了!');}).start(); }}

運行得到的結果

三道java新手入門面試題,通往自由的道路--鎖+Volatile

我們可以發(fā)現(xiàn),其實在準備數(shù)據(jù)完后,我們的initFlag的變量其實已經(jīng)改變,但是為什么還是沒有結束循環(huán)輸出**今天的世界打烊了,晚安!**這一句呢?

從之間的JMM模型,我們可以知道,不同線程之間是不能直接訪問對方工作內存中的變量,線程間變量的值的傳遞需要通過主內存中轉來完成,并且線程在修改完數(shù)值后,也不是馬上同步到主內存中,并且另一個線程也是無法感知到數(shù)據(jù)發(fā)生改變的,所以就會有可見性問題。

那我們可以加個volatile關鍵字修飾變量試下?

public static volatile boolean initFlag = false;

我們可以發(fā)現(xiàn)

三道java新手入門面試題,通往自由的道路--鎖+Volatile

在我們的變量修飾了volatile關鍵字后,就能輸出**今天的世界打烊了,晚安!**這一句了。

我們來看看圖解吧

三道java新手入門面試題,通往自由的道路--鎖+Volatile

先解釋下這其中連接的幾個單詞:

read(讀取):從主內存中讀取數(shù)據(jù) load (載入):將主內存中讀取到的數(shù)據(jù)寫入到本地(工作)內存中 user(使用):從本地內存中讀取數(shù)據(jù)給線程使用來計算 assign(賦值):線程將計算好的值重新賦值到工作內存中 store(存儲):將本地內存的數(shù)據(jù)存儲到主內存中 write(寫入):將stroe過來的變量值賦值給主內存中的變量,重新賦值。

大概講一下流程:

在線程B讀取initFlag變量后,重新賦值true給變量,此時,因為加了volatile修飾,所以會馬上將值寫入到主內存中修改變量中的值,此時因為有一個cpu總線嗅探機制會監(jiān)聽到主內存的變量值發(fā)生改變了,會把本地內存的中initFlag變量設置了失效,重新讀取一邊主內存的新值,就可以達到解決變量可見性問題。這是它第一個保證可見性的關鍵。

之前我們也有提到他如果發(fā)生指令重排序了,那是不是也不能讀取到最新的值呢。答案是不會的呢。

因為被volatile修飾的話,它會禁止指令重排序。那它主要是依靠什么指令重排序呢?它是通過內存屏障來實現(xiàn)的。什么是內存屏障?硬件層面,內存屏障分兩種:讀屏障(Load Barrier)和寫屏障(Store Barrier)。內存屏障有兩個作用:

阻止屏障兩側的指令重排序; 強制把寫緩沖區(qū)/高速緩存中的臟數(shù)據(jù)等寫回主內存,或者讓緩存中相應的數(shù)據(jù)失效。

而編譯器在生成字節(jié)碼時,會在指令序列中插入內存屏障來禁止指令重排序。這樣保證了任何程序中都能得到正確的volatile內存語義。這個策略是:

在每個volatile寫操作前插入一個StoreStore屏障; 在每個volatile寫操作后插入一個StoreLoad屏障; 在每個volatile讀操作后插入一個LoadLoad屏障; 在每個volatile讀操作后再插入一個LoadStore屏障。

看一下示意圖

三道java新手入門面試題,通往自由的道路--鎖+Volatile

小結:

volatile作用

volatile可以保證內存可見性且禁止重排序。 volatile不具備保證原子性,而鎖可以保證整個臨界區(qū)代碼的執(zhí)行具有原子性。所以而鎖可以保證整個臨界區(qū)代碼的執(zhí)行具有原子性。所以在功能上,鎖比volatile更強大;在性能上,volatile更有優(yōu)勢。2. 悲觀鎖和樂觀鎖可以講下你的理解嗎?

其實聽名字,我們就應該有個概念:

悲觀對應著我們生活中的人,悲觀的人一般看待事物都會相對消極負能量點,會盡可能往壞處去想的。這也是對應著MyGirl,她其實是一個也不能說算是悲觀的人,只能說看待事物可能會更往深入,更壞的一方面的去思考。

這其實跟我很互補,因為算是個樂天派吧,而樂觀對應著我們生活中的人,樂觀的人一般看待事物都會相對積極正能量,會盡可能往好處去想的。我其實對待生活的方方面面可能會更樂觀點,但有時帶來的一些壞處也是難以估計的。

所以說這兩者不能說誰好誰壞,只能對應著場景選擇對應的方法。

悲觀鎖:

MyGilr這個人呢,她總是會假設一種最壞的情況。比如,她每次要去拿數(shù)據(jù)的同時,認為別人也會來修改數(shù)據(jù)跟她作對,所以每次在拿數(shù)據(jù)的時候她都會上鎖,堵上一個界限,這樣別人想拿這個數(shù)據(jù)就只能等待她出去解鎖成功后,直到它拿到鎖。

在Java中,synchronized和ReentrantLock等獨占鎖就是悲觀鎖思想的實現(xiàn)。而在數(shù)據(jù)庫里邊就用到了很多這種鎖機制,比如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。

樂觀鎖:

我這個人呢,總是會假設一種最好的情況。比如, 我每次要去拿數(shù)據(jù)的同時,認為別人絕對不會來修改數(shù)據(jù)滴,所以每次拿數(shù)據(jù)的時候都不會上鎖。但是人還是要點防備心里的,不是嗎?所以在更新的時候會判斷一下在此期間別人有沒有去更新過這個數(shù)據(jù)。

而常見的有CAS算法+版本號實現(xiàn)。樂觀鎖適用于多讀的應用類型,這樣可以提高吞吐量。

在Java中,像原子類就是使用了樂觀鎖的一種實現(xiàn)方式CAS實現(xiàn)的。而在數(shù)據(jù)庫提供的類似于write_condition機制,其實都是提供的樂觀鎖。

兩者對應的場景的區(qū)別:

樂觀鎖多用于讀多寫少的環(huán)境,避免頻繁加鎖影響性能,加大了系統(tǒng)的整個吞吐量;而悲觀鎖多用于寫多讀少的環(huán)境,避免頻繁失敗和重試影響性能。

3. 你還知道什么其他的鎖嗎?

可重入鎖和非可重入鎖:

所謂重入鎖又名遞歸鎖,顧名思義。就是支持重新進入的鎖,也就是說這個鎖支持一個線程對資源重復加鎖。指在同一個線程在外層方法獲取鎖的時候,在進入內層方法會自動獲取鎖。不會因為之前已經(jīng)獲取過還沒釋放而阻塞。

在Java中,ReentrantLock和synchronized都是可重入鎖,可重入鎖的還有一個優(yōu)點是可一定程度避免死鎖。

public static void main(String[] args) { doOne();}public static synchronized void doOne(){ System.out.println('執(zhí)行第一個任務'); try {Thread.sleep(10); } catch (InterruptedException e) {e.printStackTrace(); } // 執(zhí)行第二個任務 doTwo();}public static synchronized void doTwo(){ System.out.println('執(zhí)行第二個任務');}

簡單的測試下結果:

執(zhí)行第一個任務執(zhí)行第二個任務

可以驗證得到,類中的兩個方法都是被內置鎖synchronized修飾的,而在doOne方法去調用doTwo方法時,因為是可重入鎖,所以同個線程下可以直接獲得當前對象鎖,所以synchronized是可重入鎖。

而如果我們自己在繼承AQS實現(xiàn)同步器的時候,沒有考慮到占有鎖的線程再次獲取鎖的場景,可能就會導致線程阻塞,那這個就是一個非可重入鎖。

公平鎖和非公平鎖 :

這里的公平,可以按生活上來講,如果你跟你女朋友吵架,你覺得你是正確的,最后的結果卻你必須得哄你女朋友還得道歉,你信嗎?所以這是公平的嗎?

如果對一個鎖來說,先對鎖獲取請求的線程一定會先被滿足,后對鎖獲取請求的線程后被滿足,那這個鎖就是公平的。反之,那就是不公平的。

公平鎖:

多個線程按照申請鎖的順序來獲取鎖,線程直接進入隊列中排隊,隊列中的第一個線程才能獲得鎖。公平鎖的優(yōu)點是等待鎖的線程不會餓死。

缺點是整體吞吐效率相對非公平鎖要低,等待隊列中除第一個線程以外的所有線程都會阻塞,CPU喚醒阻塞線程的開銷比非公平鎖大。

非公平鎖:

多個線程加鎖時直接嘗試獲取鎖,獲取不到才會到等待隊列的隊尾等待。但如果此時鎖剛好可用,那么這個線程可以無需阻塞直接獲取到鎖,所以非公平鎖有可能出現(xiàn)后申請鎖的線程先獲取鎖的場景。

非公平鎖的優(yōu)點是可以減少喚起線程的開銷,整體的吞吐效率高,因為線程有幾率不阻塞直接獲得鎖,CPU不必喚醒所有線程。缺點是處于等待隊列中的線程可能會餓死,或者等很久才會獲得鎖。

在Java中,對于ReentrantLock而言,可以通過構造函數(shù)指定該鎖是否是公平鎖,默認是非公平鎖。

獨享鎖和共享鎖:

對于獨享和共享,這兩個概念應該可以見名知意,對于MyGirl喜歡的東西,是碰都碰不得,而對于不喜歡,或者還可以的東西,可以和她共享。

獨享鎖:

也叫排他鎖,是指該鎖一次只能被一個線程所持有。如果線程B對變量A加上排它鎖后,則其他線程不能再對A加任何類型的鎖。獲得獨享鎖的線程即能讀數(shù)據(jù)又能修改數(shù)據(jù)。

在Java中,synchronized就是一種獨享鎖。

共享鎖

代表該鎖可被多個線程所持有。如果線程B對變量A加上共享鎖后,則其他線程只能對A再加共享鎖,不能加排它鎖。獲得共享鎖的線程只能讀數(shù)據(jù),不能修改數(shù)據(jù)。

總結

這篇文章就到這里了,如果這篇文章對你也有所幫助,希望您能多多關注好吧啦網(wǎng)的更多內容!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
新版的欧美在线视频| 亚洲三级网址| 国产精品2023| 日韩在线一区二区| 日韩一区网站| 久久久久久久久久久9不雅视频| 久久午夜精品| 九九色在线视频| 免费日韩视频| 国精品一区二区三区| 你懂的亚洲视频| 亚洲一区二区成人| 激情中国色综合| 青青草国产精品亚洲专区无| 国产欧美日韩在线观看视频 | 国精品一区二区三区| 日韩avvvv在线播放| 日韩欧美一区免费| 久久影院资源站| 久久国产尿小便嘘嘘| 日韩av影院| 电影91久久久| 久久uomeier| 亚洲精品99| 91精品xxx在线观看| 日韩一区电影| 免费观看日韩电影| 视频在线在亚洲| 国产精品欧美一区二区三区不卡| 国产一区2区在线观看| 九色精品91| 日韩av影院| 日韩精品欧美| 日本中文字幕不卡| av资源中文在线| 免播放器亚洲一区| 免费日韩成人| 国产视频一区在线观看一区免费| 日本不卡的三区四区五区| 久久婷婷国产| 久久一二三区| 国产成人a视频高清在线观看| 日韩精品一区二区三区免费观看| 亚洲精选av| 久久精品国产99久久| 国产一区日韩欧美| 久久在线视频免费观看| 欧美日韩高清| 日韩高清在线不卡| 在线精品观看| 欧美日韩一视频区二区| 日韩一区精品字幕| 天堂av在线| 国产女人18毛片水真多18精品| 在线亚洲免费| 久久国产欧美| 日韩一区三区| 国产精品黄网站| 日韩福利在线观看| 在线观看亚洲精品福利片| 妖精视频成人观看www| 婷婷综合在线| 香蕉成人久久| 色综合视频一区二区三区日韩| 黄色欧美日韩| 美女尤物久久精品| 日日夜夜免费精品视频| 日韩精品亚洲专区| 国产探花一区在线观看| 另类小说一区二区三区| av中文字幕在线观看第一页 | 国产探花一区| 国产精品中文| 亚洲福利一区| 欧美日韩国产免费观看视频| 久草免费在线视频| 蜜桃久久精品一区二区| 在线免费观看亚洲| 亚洲制服一区| 美女久久久久久| 日韩精选在线| 国产精品美女午夜爽爽| 麻豆91精品视频| 日本а中文在线天堂| 99视频精品视频高清免费| 精品国产亚洲一区二区在线观看| 国产精品视频3p| 久久毛片亚洲| 日韩专区在线视频| 欧美精品国产| 欧洲一区二区三区精品| 欧美网站在线| 国产亚洲字幕| 日韩欧美国产精品综合嫩v| 99久久久久国产精品| 一区二区三区四区在线观看国产日韩| 亚洲ww精品| 91一区二区三区四区| 九色精品91| 久久国产三级| 黄色网一区二区| 亚洲综合电影一区二区三区| 国产精品一区二区精品视频观看| 999国产精品| 日韩高清在线观看一区二区| 日韩精品1区| 日本精品久久| 国产精品99一区二区| 69堂免费精品视频在线播放| 久久久亚洲一区| 国产精品一区毛片| 午夜在线播放视频欧美| 水蜜桃精品av一区二区| 亚洲精品麻豆| 免费视频一区三区| 国产精品伦理久久久久久| 一本色道精品久久一区二区三区| 精品视频在线观看网站| 日韩三级精品| 在线午夜精品| 亚洲香蕉网站| 日本少妇一区| 大香伊人久久精品一区二区| 青青草91视频| 日韩区一区二| 日本免费一区二区视频| 精品淫伦v久久水蜜桃| 精品日韩一区| 欧美丝袜一区| 日韩专区欧美专区| 91大神在线观看线路一区| 国产精品美女| 911亚洲精品| 精品一区二区三区中文字幕 | 国产激情一区| 久久精品99国产国产精| 欧美午夜三级| 成人国产精品久久| 久久激情婷婷| 蜜臀91精品一区二区三区| 国产精品亲子伦av一区二区三区 | 成人免费网站www网站高清| 久久久久久美女精品| 在线一区免费观看| 日韩中文字幕亚洲一区二区va在线 | 国产成人a视频高清在线观看| 国产精品igao视频网网址不卡日韩| 国产伦乱精品| 国产精品精品国产一区二区| 亚洲综合不卡| 精品国产亚洲一区二区三区在线 | а√在线中文在线新版| 日韩av专区| 在线视频亚洲| 久久婷婷国产| av一区二区高清| 欧美精品国产一区| 999久久久免费精品国产| 国产亚洲精品v| 婷婷精品进入| 69堂精品视频在线播放| 毛片在线网站| 国产精品久久久久毛片大屁完整版| 日韩视频二区| 91精品婷婷色在线观看| 精品不卡一区| 少妇高潮一区二区三区99| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产三级精品三级在线观看国产| 天堂俺去俺来也www久久婷婷| 香蕉精品视频在线观看| 亲子伦视频一区二区三区| 国产一区二区三区久久久久久久久| 国产精品大片免费观看| 香蕉久久一区| 国产精品三级| 久久精品电影| 亚洲一区二区毛片| 欧美1级日本1级| 日韩中文影院| 韩国三级一区| 欧美一区三区| 免费久久精品视频| 国产欧美综合一区二区三区| 日韩精品一区二区三区中文在线| 欧美日韩高清| 影视先锋久久| 99国产精品久久久久久久 | 特黄毛片在线观看| 日韩精品一级| 一区二区三区四区日韩| 中文字幕视频精品一区二区三区| 日韩中文欧美| а√天堂8资源中文在线| 9久re热视频在线精品| 国产精品毛片在线看| 亚洲精品日本| 午夜精品网站| 黄毛片在线观看| 亚洲一区二区小说|