python—多线程之死锁
生活随笔
收集整理的這篇文章主要介紹了
python—多线程之死锁
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、造成死鎖的原因
1、在多線程程序中,死鎖問題很大一部分是由于線程同時獲取多個鎖造成的。
2、在線程間共享多個資源的時候,如果兩個線程分別占有一部分資源并且同時等待對方的資源,就會造成死鎖。
3、盡管死鎖很少發生,但一旦發生就會造成應用的停止響應。
二、產生死鎖的四個原因
1、互斥條件:一個資源每次只能被一個線程使用。
2、請求與保持條件:一個線程因請求資源而阻塞時,對已獲得的資源保持不放。3、不剝奪條件:線程已獲得的資源,在末使用完之前,不能強行剝奪。
4、循環等待條件:若干線程之間形成一種頭尾相接的循環等待資源關系。
三、代碼演示死鎖
第一種死鎖:沒有釋放鎖
執行結果:
第二種死鎖:多次調用自己
解決方法:將互斥鎖改為邏輯鎖
四、死鎖的解決方法:
讓多個線程交叉有序的競爭多個資源
總結
以上是生活随笔為你收集整理的python—多线程之死锁的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python—多线程数据混乱问题解决之同
- 下一篇: python—多线程之线程之间共享数据(