Python笔记—–线程锁
首先定义一个thread_test类,写一个run方法,首先for循环开启10个线程,调用start依次运行10个线程,调用join方法在等待线程完全结束后再退出主程序,从结果看并没有什么问题。不过当我们在func方法中加入一个time.sleep函数,可以发现结果变得无序。
这里就涉及到“锁”的问题,当多个线程同时处理一个对象时,如果没有保护好对象,就会出现这种结果。
import threading, time
n = 0
class thread_test:
def func(self):
global n
print n
n += 1
def run(self):
thread_list = []
for i in range(0,10):
t = threading.Thread(target=self.func,args=())
thread_list.append(t)
for i in range(0,10):
thread_list[i].start()
for i in range(0,10):
thread_list[i].join()
if __name__ == "__main__":
aaa = thread_test()
aaa.run()
python为我们提供了threading.Lock(),称之为锁。我们在程序中加入一个锁,当一个线程在处理对象时,将其锁住,等处理完之后,再将锁释放。此时,当多个线程同时处理同一对象时,不会发生“线程不安全”的现象。