文章詳情頁
threadingtest - python threading中的lock rlock 為何rlock可以調用多次acquire
瀏覽:117日期:2022-08-08 17:13:56
問題描述
在python的多線程中,使用threading中的lock rlock鎖, 為何rlock可以調用多次acquire,lock缺不能,lock調用多次而且會發生死鎖,rlock不會,求大神指點下
問題解答
回答1:rlock是可重入鎖,你可以簡單的理解它自帶一個計數器,acquire則計數器+1,release則計數器-1.不可出現負值,否則會跑出異常。
為什么要這么做呢,因為應用場景不同,可重入鎖可以調用另外一個需要該鎖的方法,而不可重入鎖是不能這么做的。
def fun1(): rlock.acquire() fun2() rlock.release()def fun2(): rlock.acquire() rlock.release()回答2:
lock與rlock的差別在于r: reentrant,可重復進入,一個線程可以多次獲取同一個rlock而不被block,一個線程如果多次獲取了rlock,那就要release相同的次數才可以釋放這個rlock。
lock則不一樣,只能被獲取一次,在被釋放之前,不能再被獲取。
更多的可以參考這個回答:http://stackoverflow.com/ques...
相關文章:
1. mysql儲存json錯誤2. mysql - 這種分級一對多,且分級不平衡的模型該怎么設計表?3. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?4. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf5. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?6. mysql - 表名稱前綴到底有啥用?7. mysql - 數據庫表中,兩個表互為外鍵參考如何解決8. mysql - 數據庫建字段,默認值空和empty string有什么區別 1109. mysql - 怎么生成這個sql表?10. php - 公眾號文章底部的小程序二維碼如何統計?
排行榜
