您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java中并發關鍵字有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
并發的特性
1、可見性
a、 保證任何一個線程修改變量立即寫入到主內存中(堆);
b、 所有線程對該變量引用會強制立即失效,并且該線程必須去堆中獲取最新的變量值。
2、指令重排序
代碼的執行順序 會在JVM中(編譯器優化 指令級并行重排序 內存系統重排序 最終執行的指令序列)
3、原子性
同一時刻最多只有一個線程訪問該段代碼。
Volatile -> 可見性、指令重排序
Synchronied -> 可見性、指令重排序、原子性
lock
存在價值
synchronized只在以下2種情況下會釋放鎖
1)獲取鎖的線程執行完了該代碼塊,然后線程釋放對鎖的占有;
2)線程執行發生異常,此時JVM會讓線程自動釋放鎖。
因此synchronized可能會造成線程阻塞。
為解決線程阻塞問題,引入此概念。
public interface Lock {
void lock();//獲取鎖,如果鎖被其他線程獲取,則進行等待
void lockInterruptibly() throws InterruptedException;? // tryLock()方法是有返回值的,它表示用來嘗試獲取鎖,如果獲取成功,則返回true,如果獲取失敗(即鎖已被其他線程獲取),則返回 false,也就說這個方法無論如何都會立即返回。在拿不到鎖時不會一直在那等待。? boolean tryLock();? //tryLock(long time, TimeUnit unit)方法和tryLock()方法是類似的,只不過區別在于這個方法在拿不 到鎖時會等待一定的時間,在時間期限之內如果還拿不到鎖,就返回false。如果如果一開始拿到鎖或者在等待期間內拿到了鎖,則返回true。? boolean tryLock(long time, TimeUnit unit) throws InterruptedException;? void unlock(); //釋放鎖? Condition newCondition();
}
Final
final修飾的變量不可改變,在并發編程場景下性能突出。
volatile和synchronied區別
1、volatile不會造成線程的阻塞,而synchronized可能會造成線程的阻塞。(原子性差異造成)
2、volatile只能修飾變量,而synchronized則可以修飾變量和方法。
3、當一個域的值依賴于它之前的值時,volatile就無法工作了,如n=n+1,n++等。如果某個域的值受到其他域的值的限制,那么volatile也無法工作,如Range類的lower和upper邊界,必須遵循lower<=upper的限制。
4、使用volatile而不是synchronized的唯一安全的情況是類中只有一個可變的域。
synchronized和lock區別
1)Lock是一個接口,而synchronized是Java中的關鍵字,synchronized是內置的語言實現;
2)synchronized在發生異常時,會自動釋放線程占有的鎖,因此不會導致死鎖現象發生;而Lock在發生異常時,如果沒有主動通過unLock()去釋放鎖,則很可能造成死鎖現象,因此使用Lock時需要在finally塊中釋放鎖;
3)Lock可以讓等待鎖的線程響應中斷,而synchronized卻不行,使用synchronized時,等待的線程會一直等待下去,不能夠響應中斷;
4)通過Lock可以知道有沒有成功獲取鎖,而synchronized卻無法辦到。
5)Lock可以提高多個線程進行讀操作的效率。
在性能上來說,如果競爭資源不激烈,兩者的性能是差不多的,而當競爭資源非常激烈時(即有大量線程同時競爭),此時Lock的性能要遠遠優于synchronized。所以說,在具體使用時要根據適當情況選擇。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Java中并發關鍵字有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。