Considere o seguinte código:
#/usr/bin/env python
from time import sleep
from random import random
from threading import Thread, local
data = local()
def bar():
print("I'm called from", data.v)
def foo():
bar()
class T(Thread):
def run(self):
sleep(random())
data.v = self.getName() # Thread-1 and Thread-2 accordingly
sleep(1)
foo()
>> T (). Start (); T (). Start ()
Sou chamado do Thread-2
Eu sou chamado do Tópico 1
Aqui, threading.local () é usado como uma maneira rápida e suja de passar alguns dados de run () para bar () sem alterar a interface de foo ().
Observe que usar variáveis globais não resolverá o problema:
#/usr/bin/env python
from time import sleep
from random import random
from threading import Thread
def bar():
global v
print("I'm called from", v)
def foo():
bar()
class T(Thread):
def run(self):
global v
sleep(random())
v = self.getName() # Thread-1 and Thread-2 accordingly
sleep(1)
foo()
>> T (). Start (); T (). Start ()
Sou chamado do Thread-2
Sou chamado do Thread-2
Enquanto isso, se você pudesse passar esses dados como um argumento de foo (), seria uma maneira mais elegante e bem projetada:
from threading import Thread
def bar(v):
print("I'm called from", v)
def foo(v):
bar(v)
class T(Thread):
def run(self):
foo(self.getName())
Mas isso nem sempre é possível ao usar código de terceiros ou mal projetado.