[New-bugs-announce] [issue20775] Modifications to global variables ignored after instantiating multiprocessing.Pool
Naftali Harris
report at bugs.python.org
Tue Feb 25 23:00:00 CET 2014
New submission from Naftali Harris:
Hi everyone,
It appears that if you use a global variable in a function that you pass to Pool.map, but modify that global variable after instantiating the Pool, then the modification will not be reflected when Pool.map calls that function.
Here's a short script, (also attached), that demonstrates what I mean:
$ cat reproduces.py
from multiprocessing import Pool
name = "Not Updated"
def f(ignored):
print(name)
def main():
global name
p = Pool(3)
name = "Updated"
p.map(f, range(3))
if __name__ == "__main__":
main()
$ python reproduces.py
Not Updated
Not Updated
Not Updated
If the `name = "Updated"' line is moved above the `p = Pool(3)' line, then the script will print "Updated" three times instead.
This behavior is present in versions 2.6, 2.7, 3.1, 3.2, 3.3, and 3.4. I run Linux Mint 14 (nadia), on an Intel i5-3210M processor (four cores).
Is this expected behavior?
Thanks very much,
Naftali
----------
components: Library (Lib)
files: reproduces.py
messages: 212221
nosy: Naftali.Harris
priority: normal
severity: normal
status: open
title: Modifications to global variables ignored after instantiating multiprocessing.Pool
type: behavior
versions: Python 2.7, Python 3.1, Python 3.2, Python 3.3, Python 3.4
Added file: http://bugs.python.org/file34223/reproduces.py
_______________________________________
Python tracker <report at bugs.python.org>
<http://bugs.python.org/issue20775>
_______________________________________
More information about the New-bugs-announce
mailing list