Python實現多進程共享數據的方法分析
更新時間:2017年12月04日 10:39:47 作者:HeatDeath
這篇文章主要介紹了Python實現多進程共享數據的方法,結合實例形式分析了Python多進程共享數據的相關實現技巧,需要的朋友可以參考下
本文實例講述了Python實現多進程共享數據的方法。分享給大家供大家參考,具體如下:
示例一:
# -*- coding:utf-8 -*- from multiprocessing import Process, Manager import time import random def kkk(a_list, number): for i in range(10): a_list.append(i) time.sleep(random.randrange(2)) print('這是進程{} {}'.format(number, a_list)) print('這是進程{} {}'.format(number, a_list)) def jjj(a_list): for i in range(2): process = Process(target=kkk, args=(a_list, i)) process.start() if __name__ == '__main__': a_list = [] process_0 = Process(target=jjj, args=(a_list,)) process_0.start() process_0.join() print(a_list) print(len(a_list)) print('it\'s ok')
輸出:
這是進程0 [0] 這是進程0 [0, 1] 這是進程0 [0, 1, 2] 這是進程0 [0, 1, 2, 3] 這是進程1 [0] 這是進程0 [0, 1, 2, 3, 4] 這是進程1 [0, 1] 這是進程0 [0, 1, 2, 3, 4, 5] 這是進程1 [0, 1, 2] 這是進程1 [0, 1, 2, 3] 這是進程1 [0, 1, 2, 3, 4] 這是進程1 [0, 1, 2, 3, 4, 5] 這是進程0 [0, 1, 2, 3, 4, 5, 6] 這是進程0 [0, 1, 2, 3, 4, 5, 6, 7] 這是進程0 [0, 1, 2, 3, 4, 5, 6, 7, 8] 這是進程1 [0, 1, 2, 3, 4, 5, 6] 這是進程0 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 這是進程0 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 這是進程1 [0, 1, 2, 3, 4, 5, 6, 7] 這是進程1 [0, 1, 2, 3, 4, 5, 6, 7, 8] 這是進程1 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 這是進程1 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] [] 0 it's ok Process finished with exit code 0
示例二:
使用 Manager
# -*- coding:utf-8 -*- from multiprocessing import Process, Manager import time import random def kkk(a_list, number): for i in range(10): a_list.append(i) time.sleep(random.randrange(2)) print('這是進程{} {}'.format(number, a_list)) print('這是進程{} {}'.format(number, a_list)) def jjj(a_list): for i in range(2): process = Process(target=kkk, args=(a_list, i)) process.start() if __name__ == '__main__': manager = Manager() a_list = manager.list() # a_list = [] process_0 = Process(target=jjj, args=(a_list,)) process_0.start() process_0.join() print(a_list) print(len(a_list)) print('it\'s ok')
輸出:
這是進程0 [0, 0] 這是進程0 [0, 0, 1] 這是進程0 [0, 0, 1, 2] 這是進程0 [0, 0, 1, 2, 3] 這是進程0 [0, 0, 1, 2, 3, 4] 這是進程1 [0, 0, 1, 2, 3, 4, 5] 這是進程0 [0, 0, 1, 2, 3, 4, 5, 1] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5] 這是進程0 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6] 這是進程0 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7] 這是進程0 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7] 這是進程0 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7, 8] 這是進程0 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7, 8] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7, 8] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7, 8, 9] 這是進程1 [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7, 8, 9] [0, 0, 1, 2, 3, 4, 5, 1, 6, 2, 3, 4, 5, 6, 7, 8, 9, 7, 8, 9] 20 it's ok Process finished with exit code 0
更多關于Python相關內容感興趣的讀者可查看本站專題:《Python進程與線程操作技巧總結》、《Python Socket編程技巧總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。