java web java的可重入鎖用在哪些場合?
java的可重入鎖用在哪些場合?你好,我是[不要隨波逐流]。我很高興為你回答。遠程標準教育為您解答:重入鎖是指同一個鎖可以在一個線程中多次獲得。例如,如果一個線程正在執(zhí)行一個帶有鎖的方法,而該方法調(diào)用
java的可重入鎖用在哪些場合?
你好,我是[不要隨波逐流]。我很高興為你回答。遠程標準教育為您解答:重入鎖是指同一個鎖可以在一個線程中多次獲得。例如,如果一個線程正在執(zhí)行一個帶有鎖的方法,而該方法調(diào)用另一個需要相同鎖的方法,那么該線程可以直接執(zhí)行調(diào)用方法而不必重新獲取鎖。更多專業(yè)科普知識,請關注我。如果你喜歡我的回答,也請給我表揚或轉發(fā),你的鼓勵是支持我寫下來的動力,謝謝。
如何理解Java鎖的可重入性?
可重入鎖:支持重復輸入的鎖。這意味著鎖可以支持線程對資源的重復鎖定。
關鍵字“sychronized”隱式支持重入,例如使用sychronized修改的遞歸方法。在方法執(zhí)行期間,執(zhí)行線程在獲取鎖之后可以多次獲取鎖。
盡管reentrantlock不能像sychnronized關鍵字那樣隱式地重新輸入,但是在調(diào)用lock()方法時,獲得鎖的線程可以再次調(diào)用lock()方法來獲得鎖,而不會被阻止。
可重入鎖的原理?
重入鎖實現(xiàn)的原理或機制如下:
每個鎖都與線程保持器和計數(shù)器相關聯(lián)。當計數(shù)器為0時,表示鎖沒有被任何線程持有,那么任何線程都可以獲得鎖并調(diào)用相應的方法。當線程請求成功時,JVM將記錄持有鎖的線程,并將計數(shù)器設置為0 1。此時,如果其他線程請求鎖,則必須等待;如果持有鎖的線程再次請求鎖,則可以再次獲得鎖,計數(shù)器將增加;當線程退出同步代碼塊時,計數(shù)器將減少;如果計數(shù)器為0,則釋放鎖。
分布式鎖為什么要具備可重入性?
由于我們不能準確的知道鎖的業(yè)務邏輯的耗時,并且根據(jù)當時機器的狀態(tài)和各種原因,鎖的業(yè)務邏輯的耗時不是一個固定的值,所以鎖過期時間的設置不夠準確。一旦redis在邏輯結束之前釋放了線程a的鎖,其他線程就可以獲得該鎖,就像鎖邏輯一樣。此時,線程a的邏輯執(zhí)行未完成,因此鎖邏輯由兩個線程同時執(zhí)行,仍然存在線程安全問題。為了解決這個問題,我們需要考慮重入鎖。