Warum verhält sich multiprocessing.Process unter Windows und Linux für globale Objekt- und Funktionsargumente anders?
Der folgende Code hat eine andere Ausgabe, wenn er unter Windows und Linux ausgeführt wird (beide mit python2.7).
'''import_mock.py'''
to_mock = None
'''test.py'''
import import_mock
from multiprocessing import Process
class A(object):
def __init__(self):
self.a = 1
self.b = 2
self.c = 3
def __getstate__(self):
print '__getstate__'
return { 'a': self.a, 'b': self.b,
'c':0 }
def func():
import_mock.to_mock = 1
a = A()
return a
def func1(a):
print a.a, a.b, a.c
print import_mock.to_mock
if __name__ == '__main__':
a = func()
p = Process(target=func1, args=(a,))
p.start()
p.join()
n Windows lautet die Ausgabe:
__getstate__
1 2 0
None
Was ist was ich erwartet habe
nter Linux ist es:
1 2 3
1
Welche das globale Objekt und die übergebenen Argumente nicht klonen.
Meine Frage ist, warum sie sich anders verhalten? Und wie verhält sich der Linux-Code genauso wie der Windows-Code?