如何正确使用threading.local()传值?
How to use threading.local() correctly to pass values?
此代码为何有效:
data = local()
def main():
proc = multiprocessing.Process(target = foo)
proc.start()
def foo():
data.stuff = 'happiness'
bar()
def bar():
print data.stuff
但是这个代码不起作用?
def main():
proc = multiprocessing.Process(target = foo)
proc.start()
def foo():
local().stuff = 'happiness'
bar()
def bar():
print local().stuff
我们将代码分成几个模块,并且它有多个线程。我们需要将值传递给需要保留在所有这些模块中的线程。
例如:
我们实例化一个工作包。
# inside module_name_a.py
work = Work(a, b, c)
proc = multiprocessing.Process(target = work.do_this)
proc.start()
我们正在做这项工作,我们需要在线程中全局存储一些数据。我们无法更改详细信息的 API。
# inside work_module_b.py
class Work():
.
.
.
def do_this():
detail = Detail(x, y, z)
local().stuff = 'important'
detail.handle_this()
我们需要 handle_this()
的主体到 "see" threading.local()
中的值
# inside detail_module_b.py
class Detail():
.
.
.
def do_this():
detail = Detail(x, y, z)
local().stuff = 'important'
detail.handle_this()
关于正确使用 threading.local() 的任何建议?
每次调用 local() 时,您都会获得一个新的线程本地实例。如果调用它两次,就会得到两个不同的本地对象。
就像在做
new Car().setColor(red)
new Car().getColor()
您的示例调用了 local 两次,因此您正在处理两个不同的对象。
def main():
proc = multiprocessing.Process(target = foo)
proc.start()
def foo():
local().stuff = 'happiness'
bar()
def bar():
print local().stuff
此代码为何有效:
data = local()
def main():
proc = multiprocessing.Process(target = foo)
proc.start()
def foo():
data.stuff = 'happiness'
bar()
def bar():
print data.stuff
但是这个代码不起作用?
def main():
proc = multiprocessing.Process(target = foo)
proc.start()
def foo():
local().stuff = 'happiness'
bar()
def bar():
print local().stuff
我们将代码分成几个模块,并且它有多个线程。我们需要将值传递给需要保留在所有这些模块中的线程。
例如:
我们实例化一个工作包。
# inside module_name_a.py
work = Work(a, b, c)
proc = multiprocessing.Process(target = work.do_this)
proc.start()
我们正在做这项工作,我们需要在线程中全局存储一些数据。我们无法更改详细信息的 API。
# inside work_module_b.py
class Work():
.
.
.
def do_this():
detail = Detail(x, y, z)
local().stuff = 'important'
detail.handle_this()
我们需要 handle_this()
的主体到 "see" threading.local()
# inside detail_module_b.py
class Detail():
.
.
.
def do_this():
detail = Detail(x, y, z)
local().stuff = 'important'
detail.handle_this()
关于正确使用 threading.local() 的任何建议?
每次调用 local() 时,您都会获得一个新的线程本地实例。如果调用它两次,就会得到两个不同的本地对象。
就像在做
new Car().setColor(red)
new Car().getColor()
您的示例调用了 local 两次,因此您正在处理两个不同的对象。
def main():
proc = multiprocessing.Process(target = foo)
proc.start()
def foo():
local().stuff = 'happiness'
bar()
def bar():
print local().stuff