[問題] multiprocess + sleep + Lock問題

看板Python作者 (Alan)時間7年前 (2018/01/30 23:34), 7年前編輯推噓1(1014)
留言15則, 7人參與, 7年前最新討論串1/1
from time import sleep from multiprocessing import Process, Lock def time_delay(d): sleep(d) def printer(item, lock): print(item) lock.acquire() print('time delay start') time_delay(1) print('time delay end') lock.release() if __name__ == '__main__': lock = Lock() items = ['item1', 'item2', 'item3'] for item in items: p = Process(target=printer, args=(item, lock)) p.start() 請問各位前輩,為何輸出結果是 item1 time delay start time delay end item2 time delay start time delay end item3 time delay start time delay end 而不是 item1 item2 item3 time delay start time delay end time delay start time delay end time delay start time delay end 明明print item的時候還沒被Lock住阿... 而且他是先執行time_delay才開始print item... 請問是我哪裡誤會了lock的用法? 謝謝各位! -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.169.214.73 ※ 文章網址: https://www.ptt.cc/bbs/Python/M.1517326477.A.A90.html ※ 編輯: FFALAN (1.169.214.73), 01/30/2018 23:36:38

01/31 00:27, 7年前 , 1F
版本 平台
01/31 00:27, 1F

02/01 17:29, 7年前 , 2F
Multiprocess 可能的狀況太多了, 這樣根本無法解
02/01 17:29, 2F

02/01 17:30, 7年前 , 3F
Lock 本身就是很不可靠的東西, 我唯一的建議是不要用
02/01 17:30, 3F

02/02 00:44, 7年前 , 4F
2.7/windows
02/02 00:44, 4F

02/02 20:33, 7年前 , 5F
multiprocess這個情況跑出來的順序不一定是可預期的
02/02 20:33, 5F

02/02 20:33, 7年前 , 6F
你這段code我直接拿來跑,結果就和你的不一樣
02/02 20:33, 6F

02/02 20:34, 7年前 , 7F
lock的目的是確保acquire和release之間同時只會有一人執行
02/02 20:34, 7F

02/04 03:03, 7年前 , 8F
lock.acquire() 不是指"上鎖" 應該要理解成,lock是一把
02/04 03:03, 8F

02/04 03:05, 7年前 , 9F
大家共用的鎖.而lock.acquire()要解釋成:如果lock沒被
02/04 03:05, 9F

02/04 03:06, 7年前 , 10F
上鎖,那我(這一條線程)就把鎖鎖上.然後接著執行後面的
02/04 03:06, 10F

02/04 03:07, 7年前 , 11F
code 若有其他線程先鎖住了,那我就在這行待命,直到鎖
02/04 03:07, 11F

02/04 03:08, 7年前 , 12F
解開
02/04 03:08, 12F

03/06 03:44, 7年前 , 13F
03/06 03:44, 13F

03/06 04:22, 7年前 , 14F
03/06 04:22, 14F

03/06 04:35, 7年前 , 15F
03/06 04:35, 15F
文章代碼(AID): #1QS92DgG (Python)
文章代碼(AID): #1QS92DgG (Python)