国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

java - 并發ConcurrentHashMap的問題

瀏覽:114日期:2023-12-19 09:31:03

問題描述

這個問題的 說明有點長,

step1 并發map中的putjava - 并發ConcurrentHashMap的問題

step2

java - 并發ConcurrentHashMap的問題

step3java - 并發ConcurrentHashMap的問題

step4

java - 并發ConcurrentHashMap的問題

step5java - 并發ConcurrentHashMap的問題

step6java - 并發ConcurrentHashMap的問題

step7java - 并發ConcurrentHashMap的問題

step8java - 并發ConcurrentHashMap的問題

step9java - 并發ConcurrentHashMap的問題

上面中steop3 表示重復嘗試獲取鎖達到一定的次數之后就 調用lock阻塞當前線程

我想問的問題是關鍵在 step7 這個if中的tryAcquire 表示的是嘗試獲取鎖,如果獲取不成功就返回false,然后將創建一個Node 封裝 當前線程添加到一個隊列中(1)其中if的第二個條件表示什么意思? ,好像不僅僅是獲取一個節點那么簡單的

(2)selfInterrupt 表示自我中斷,中斷不是說讓當前線程放棄正在執行的任務嗎(并不是立即放棄,是下次cpu檢查的時候查看中斷位是嗎)

而我的理解是:這里的需求是需要將當前線程阻塞,因為當前線程始終獲取不到鎖,而這里的實現是使用了中斷,中斷可以阻塞線程嗎?(平時使用中斷不都是中斷正在等待或者阻塞的線程嗎?)

(3)其實最本質想問的是,ReentrantLock實現中 ,當一個線程多次嘗試獲取不到鎖之后是如何阻塞當前線程的? 阻塞之后又是如何喚醒的

求各位開導吶

問題解答

回答1:

謝邀,不過實在無法回答,因為首先我自己沒怎么研究過ConcurrentHashMap的源碼,其次面試中幾乎不太可能問到這么細節的地方。除非你自己需要寫類似guava的類庫,否則我感覺研究這些意義不是太大。

回答2:

謝邀,不過很抱歉,鄙人對于并發相關的學習也還很有限。我幫你邀請可能會的人來回答吧

回答3:

我能回答多少就回答多少吧問題(1)涉及到的是公平鎖的問題,如果獲取不到就插入Node到隊列中去,重點關注java.util.concurrent.locks.AbstractQueuedSynchronizer問題(3)線程將自己掛起,這部分的實現是依靠底層的,參照LockSupport

public static void park(Object blocker) { Thread t = Thread.currentThread(); setBlocker(t, blocker); unsafe.park(false, 0L); setBlocker(t, null);}

喚醒用unpark方法

標簽: java
相關文章:
主站蜘蛛池模板: 免费看特级毛片 | 又黄又免费的网站 | 成人在线第一页 | 亚洲综合片 | 成人国产一区二区 | 91精品视频在线播放 | 欧美叫床戏做爰无遮挡 | 日韩一区二区三区四区 | 精品久久一区二区三区 | 久久久久久国产精品视频 | 婷婷色九月综合激情丁香 | 午夜爽爽性刺激一区二区视频 | 国产aaa女人十八毛片 | 日日操干 | a毛片a毛片a视频 | 日韩二区三区 | 香蕉香蕉国产片一级一级毛片 | 91丨九色丨首页在线观看 | 精品国产免费观看 | 国产精品天天爽夜夜欢张柏芝 | 国产成人a一区二区 | 国内精品视频成人一区二区 | 中文字幕精品一区二区绿巨人 | 成人做爰www | 一级毛片一级毛片a毛片欧美 | 成人国产精品免费网站 | 午夜三级a三级三点在线观看 | 日本不卡一区视频 | 全部在线播放免费毛片 | 在线视频精品一区 | 91精品手机国产露脸 | 亚州视频在线 | 国产精品色内内在线播放 | 欧美13一14周岁a在线播放 | 男操女免费视频 | 久草手机视频在线观看 | 午夜爽爽性刺激一区二区视频 | 久久99精品久久久久久野外 | 一级做a爰片久久毛片人呢 一级做a爰片久久毛片唾 | 国产成人在线综合 | 国产免费人视频在线观看免费 |