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?

Antworten auf die Frage(4)

Ihre Antwort auf die Frage