Python多線程編程之多線程加鎖


Python語言本身是支持多線程的,不像PHP語言。

下面的例子是多個線程做同一批任務,任務總是有task_num個,每次線程做一個任務(print),做完后繼續取任務,直到所有任務完成為止。

 1 #coding:utf-8
 2 import threading
 3 
 4 start_task = 0
 5 task_num = 10000
 6 mu = threading.Lock()   ###通過工廠方法獲取一個新的鎖對象
 7 
 8 class MyThread(threading.Thread):   ###類MyThread繼承基類threading.Thread
 9 
10     def run(self):  ##線程啟動的入口函數,子類需重寫
11         global start_task
12         global mu
13         global start_task
14 
15         while start_task < task_num:    ##如果任務沒有完成,則繼續
16             if mu.acquire():    ##加鎖
17                 if start_task < task_num:
18                     print start_task
19                     start_task = start_task + 1
20                 mu.release()    ##釋放鎖
21 
22 def test():
23     thread_all = []
24     for i in range(6):  ##for循環創建6個線程
25         t = MyThread()  ##創建線程
26         thread_all.append(t)
27         t.start()   ###啟動線程
28 
29     for i in range(6):
30         thread_all[i].join()    ##等待線程結束
31 
32 if __name__ == "__main__":
33     test()

 

測試加鎖與不加鎖效果:將任務數設置為1千萬或者以上,在多核機器上將print輸出分別保存,就能說明問題。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM