赞
踩
在多线程中,同一个进程中的多个线程是共享一个内存地址的,多个线程操作数据时,就会造成数据的不安全,所有我们就要加锁。但是对于一些变量,如果仅仅只在本线程中使用,怎么办?
方法1:可以通过全局的字典,key为当前线程的线程ID,value为具体的值。
方法2:使用threadding.local方法
threading.local在多线程操作时,为每一个线程创建一个值,使得线程之间各自操作自己的值,互不影响。
- from threading import local
- import time
-
- class Foo(local):
- pass
-
- foo = Foo()
- foo.num = 1
-
- def my_num(i):
- foo.num = i
- # time.sleep(1)
- print(foo.num, threading.current_thread().ident)
-
- for i in range(10):
- th = threading.Thread(target=my_num,args=(i,))
- th.start()
- class MyStack(object):
- data = []
-
- def __setattr__(self, key, value):
- self.push(key,value)
-
- def push(s
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。