日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java高并发(十九)死锁、spring线程安全

發布時間:2024/9/16 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java高并发(十九)死锁、spring线程安全 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

死鎖的必要條件

  • 互斥條件
  • 請求和保持條件
  • 不剝奪條件
  • 環路等待條件
/*** 一個簡單的死鎖類* 當DeadLock的對象flag==1時(d1), 先鎖定o1,睡眠500毫秒* 而d1在睡眠的時候留一個flag=0的對象(d2)線程啟動,先鎖定o2,睡眠500毫秒* d1睡眠結束后需要鎖定o2才能繼續執行,而此時o2已經被d2鎖定;* d2睡眠結束后需要鎖定o1才能繼續執行,而此時o1已經被d1鎖定;* d1,d2相互等待,都需要得到對方鎖定改的資源才能繼續執行,從而死鎖*/ @Slf4j public class DeadLock implements Runnable {public int flag = 1;//靜態資源是類的所有對象共享的private static Object o1 = new Object(), o2 = new Object();@Overridepublic void run() {log.info("flag:{}", flag);if(flag == 1){synchronized (o1) {try{Thread.sleep(500);} catch (Exception e){e.printStackTrace();}synchronized (o2) {log.info("1");}}}if (flag == 0) {synchronized (o2) {try {Thread.sleep(500);}catch (Exception e){e.printStackTrace();}synchronized (o1) {log.info("0");}}}}public static void main(String[] args) {DeadLock d1 = new DeadLock();DeadLock d2 = new DeadLock();d1.flag = 1;d2.flag = 0;//d1,d2都處于可執行狀態,但JVM線程調度先執行哪個線程是不確定的。//d2的run()可能在d1的run()之前執行new Thread(d1).start();new Thread(d2).start();} }

如何避免死鎖:

  • 注意加鎖順序?
  • 加鎖時間限制,可以使用ReentrantLock可以設置獲取所得給定時間,超過一定時間就釋放自己占用的鎖

spring與線程安全

spring bean:提供了一個scope屬性來表示該bean的作用域,是bean的生命周期。例如scope=singleton,表示單例,在第一次注入時會產生一個單例對象,該對象會一直復用到應用結束,這時默認的scope;

????scope=prototype,表示在每次注入時都會創建一個bean對象

總結

以上是生活随笔為你收集整理的java高并发(十九)死锁、spring线程安全的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。