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

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

Java 多線程Synchronized和Lock的區別

瀏覽:16日期:2022-08-18 18:10:52
引言

在多線程中,為了使線程安全,我們經常會使用synchronized和Lock進行代碼同步和加鎖,但是具體兩者有什么區別,什么場景下適合用什么可能還不大清楚,主要的區別大致如下:

區別

1、synchronized是java關鍵字,而Lock是java中的一個接口

2、synchronized會自動釋放鎖,而Lock必須手動釋放鎖

3、synchronized是不可中斷的,Lock可以中斷也可以不中斷

4、通過Lock可以知道線程有沒有拿到鎖,而synchronized不能

5、synchronized能鎖住方法和代碼塊,而Lock只能鎖住代碼塊

6、Lock可以使用讀鎖提高多線程讀效率

7、synchronized是非公平鎖,ReentranLock可以控制是否公平鎖

從Lock接口中我們可以看到主要有5個方法,這些方法的功能從注釋中可以看出:

lock():獲取鎖,如果鎖被暫用則一直等待unlock():釋放鎖tryLock(): 注意返回類型是boolean,如果獲取鎖的時候鎖被占用就返回false,否則返回truetryLock(long time, TimeUnit unit):比起tryLock()就是給了一個時間期限,保證等待參數時間lockInterruptibly():用該鎖的獲得方式,如果線程在獲取鎖的階段進入了等待,那么可以中斷此線程,先去做別的事 通過 以上的解釋,大致可以解釋在上個部分中“鎖類型(lockInterruptibly())”,“鎖狀態(tryLock())”等問題,還有就是前面子所獲取的過程我所寫的“大致就是可以嘗試獲得鎖,線程可以不會一直等待”用了“可以”的原因。lock():

public class LockTest { private Lock lock = new ReentrantLock(); private void method(Thread thread) { lock.lock(); try { System.out.println(thread.getName() + ' has gotten the lock!'); } catch (Exception e) { e.printStackTrace(); } finally { System.out.println(thread.getName() + ' has unlocked the lock!'); lock.unlock(); } } public static void main(String[] args) { final LockTest test = new LockTest(); Thread t1 = new Thread(new Runnable() { @Override public void run() {test.method(Thread.currentThread()); } }, 't1'); Thread t2 = new Thread(new Runnable() { @Override public void run() {test.method(Thread.currentThread()); } }, 't2'); t1.start(); t2.start(); }}

運行結果:

t1 has gotten the lock!t1 has unlocked the lock!t2 has gotten the lock!t2 has unlocked the lock!tryLock():

public class LockTest { private Lock lock = new ReentrantLock(); private void method(Thread thread) { if (lock.tryLock()) { lock.lock(); try {System.out.println(thread.getName() + ' has gotten the lock!'); } catch (Exception e) {e.printStackTrace(); } finally {System.out.println(thread.getName() + ' has unlocked the lock!');lock.unlock(); } } else { System.out.println('I’m '+thread.getName()+'. Someone has gotten the lock!'); } } public static void main(String[] args) { LockTest test = new LockTest(); Thread t1 = new Thread(() -> test.method(Thread.currentThread()), 't1'); Thread t2 = new Thread(new Runnable() { @Override public void run() {test.method(Thread.currentThread()); } }, 't2'); t1.start(); t2.start(); }}

運行結果:

t1 has gotten the lock!t1 has unlocked the lock!I’m t2. Someone has gotten the lock!

看到這里相信大家也都會使用如何使用Lock了吧,關于tryLock(long time, TimeUnit unit)和lockInterruptibly()不再贅述。前者主要存在一個等待時間,在測試代碼中寫入一個等待時間,后者主要是等待中斷,會拋出一個中斷異常,常用度不高,喜歡探究可以自己深入研究。

以上就是Java 多線程Synchronized和Lock的區別的詳細內容,更多關于Java 多線程Synchronized和Lock的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 亚洲成人黄色在线观看 | 国产在线精品一区二区不卡 | 国产精品路边足疗店按摩 | 免费播放国产性色生活片 | 搞黄网站免费观看 | 91久久香蕉国产线看观看软件 | 亚洲免费色视频 | 俄罗斯18videosex性欧美成人 | 亚洲成网站 | 99精品99| 免费观看a黄一级视频 | 欧美a欧美1级 | 日本国产免费一区不卡在线 | 99精品视频在线播放2 | 欧美成人aaaa免费高清 | 中文在线免费视频 | 国产高清一国产免费软件 | 国产成人精品免费视频大全办公室 | 中国一级毛片aaa片 中国一级毛片录像 | 成 人 黄 色 视频 免费观看 | 一级a性色生活片久久毛片 一级a做爰片欧欧美毛片4 | 亚洲免费视频网 | 亚洲成年www | 搞黄网站免费观看 | 亚洲精品午夜一区二区在线观看 | 美女视频网站永久免费观看软件 | 欧美日韩一区二区三在线 | 国产成人午夜精品影院游乐网 | 美女黄页黄频 | 国产一级特黄aa级特黄裸毛片 | 欧美成人午夜毛片免费影院 | 欧洲成人在线视频 | 久久久久久毛片免费播放 | 成人精品一区二区三区 | 狼伊千合综网中文 | 91精品福利手机国产在线 | 久色乳综合思思在线视频 | 国产黄色片在线观看 | 九九国产在线视频 | 在线观看免费黄视频 | 免费播放欧美毛片欧美aaaaa |