java中鎖的概念 多個線程可以讀一個變量,只有一個線程可以對這個變量進行寫,到底要不要加鎖?
多個線程可以讀一個變量,只有一個線程可以對這個變量進行寫,到底要不要加鎖?下面簡要解釋一下原因:鎖定是因為操作不是原子的。讓我們用操作一來解釋它??聪旅鎯蓚€圖。我這個操作需要看上面的第二個圖,你能很清
多個線程可以讀一個變量,只有一個線程可以對這個變量進行寫,到底要不要加鎖?
下面簡要解釋一下原因:
鎖定是因為操作不是原子的。讓我們用操作一來解釋它。看下面兩個圖。
我這個操作需要
看上面的第二個圖,你能很清楚地理解這個過程嗎?
鎖定是為了確保上述三個步驟是原子操作。
回到問題上來,只有一個線程要寫,沒有競爭,所以不需要鎖定。
但是,如果你看第一張圖片,因為主內(nèi)存和本地內(nèi)存的存在
在一個線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關(guān)鍵字后,它將在操作后強制工作內(nèi)存和主內(nèi)存同步,以確保其他線程可以立即看到它。
java synchronized鎖對象,當對象引用是null的時候,鎖的是什么?
謝謝
!Java語言規(guī)范明確指出,如果鎖定的對象為null,則會發(fā)生NullPointerException。規(guī)范的內(nèi)容如下:
表達式的類型必須是引用類型,否則會發(fā)生完全時間錯誤。首先計算表達式,執(zhí)行同步語句。然后:如果表達式的求值由于某種原因完全完成,那么synchronized語句也會因為同樣的原因突然完成。否則,如果表達式的值為null,則會引發(fā)NullPointerException。
如何理解Java鎖的可重入性?
reentrantlock:支持重復(fù)輸入的鎖,這意味著該鎖可以支持線程對資源的重復(fù)鎖定。
關(guān)鍵字“sychronized”隱式支持重入,例如使用sychronized修改的遞歸方法。在方法執(zhí)行期間,執(zhí)行線程在獲取鎖之后可以多次獲取鎖。
盡管reentrantlock不能像sychnronized關(guān)鍵字那樣隱式地重新輸入,但是在調(diào)用lock()方法時,獲得鎖的線程可以再次調(diào)用lock()方法來獲得鎖,而不會被阻止。
java的可重入鎖用在哪些場合?
你好,我是[不要隨波逐流]。我很高興為你回答。遠程標準教育為您解答:重入鎖是指同一個鎖可以在一個線程中多次獲得。例如,如果一個線程正在執(zhí)行一個帶有鎖的方法,而該方法調(diào)用另一個需要相同鎖的方法,那么該線程可以直接執(zhí)行調(diào)用方法而不必重新獲取鎖。更多專業(yè)科普知識,請關(guān)注我。如果你喜歡我的回答,也請給我表揚或轉(zhuǎn)發(fā),你的鼓勵是支持我寫下來的動力,謝謝。