[問題] multiprocess + sleep + Lock問題
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
02/01 17:29, 2F
→
02/01 17:30,
7年前
, 3F
02/01 17:30, 3F
→
02/02 00:44,
7年前
, 4F
02/02 00:44, 4F
推
02/02 20:33,
7年前
, 5F
02/02 20:33, 5F
→
02/02 20:33,
7年前
, 6F
02/02 20:33, 6F
→
02/02 20:34,
7年前
, 7F
02/02 20:34, 7F
→
02/04 03:03,
7年前
, 8F
02/04 03:03, 8F
→
02/04 03:05,
7年前
, 9F
02/04 03:05, 9F
→
02/04 03:06,
7年前
, 10F
02/04 03:06, 10F
→
02/04 03:07,
7年前
, 11F
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
Python 近期熱門文章
PTT數位生活區 即時熱門文章