Python實現多進程共用資料的方法分析,python實現進程共用

來源:互聯網
上載者:User

Python實現多進程共用資料的方法分析,python實現進程共用

本文執行個體講述了Python實現多進程共用資料的方法。分享給大家供大家參考,具體如下:

樣本一:

# -*- coding:utf-8 -*-from multiprocessing import Process, Managerimport timeimport randomdef 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][]0it's okProcess finished with exit code 0

樣本二:

使用 Manager

# -*- coding:utf-8 -*-from multiprocessing import Process, Managerimport timeimport randomdef 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]20it's okProcess finished with exit code 0

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.