import threading
import time
num=0
def Mylock(lock):
global num
lock.acquire()
num=num+1
time.sleep(1)
print num,
lock.release()
lock=threading.Lock()
for item in range(5):
t=threading.Thread(target=Mylock,args=(lock,))
t.start()
1 2 3 4 5
#可以去掉lock,那么会发现输出为55555,这说明一个问题,当一个线程执行到time.sleep(1)时,其它线程开始计算num=num+1,极短的时间内五个线程全部都执行了num这句,然后大家一起等一秒后输出,所以结果都是5