簡體   English   中英

Python多處理問題

[英]Python multiprocessing issue

我有一小段代碼,用python編寫,有一個Generate類,在調用時返回下一個數字。

class Generate:
    def iter(self):
        self.next1 = 1
        return self
    def next(self):
        self.curr = self.next1
        self.next1 += 1
        return self.curr

def generateNos():
    for i in xrange(3):
        print g.next()

g = Generate().iter()

generateNos()
generateNos()

並且函數generateNos,僅生成3個Nos。 因此,當我將此函數調用兩次,如下所示:輸出為: - 1 2 3 4 5 6

現在,當我生成兩個用於調用此generateNos()的進程時,我得到的輸出為: - 1 2 3 1 2 3

相同的代碼是: -

from multiprocessing import Process, Manager
class Generate:
    def iter(self):
        self.next1 = 1
        return self
    def next(self):
        self.curr = self.next1
        self.next1 += 1
        return self.curr

def generateNos():
    for i in xrange(3):
        print g.next()

g = Generate().iter()

p1 = Process(target = generateNos)
p2 = Process(target = generateNos)

p1.start()
p1.join()

p2.start()
p2.join()

現在看來這個Generate類在子進程中再次重新初始化,這是我不想要的。 我怎么能避免這個?

想要采取相同的行為,一次又一次地調用generateNos兩次。

任何hack,以便Generate()對象“g = Generate()。iter()”在子進程中不再被調用,它應該只在Parent進程中被調用一次。

您必須通過共享內存或其他允許它們實際共享同一對象實例的機制在進程之間共享對象。 啟動一個新的子進程實際上會將您傳入的所有內容發送到子進程,然后在子進程中重建一個副本。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM