首页 > 编程语言 > 详细

python多线程之线程锁一(同一时间一个线程获得一把线程锁)

时间:2017-02-17 15:49:05      阅读:364      评论:0      收藏:0      [点我收藏+]
#coding:utf-8
‘‘‘线程锁‘‘‘
import threading
import time

num = 0 #全局变量

def runs():
    time.sleep(1)
    global num #在函数内部要对全局变量进行更改,需要进行声明
    lock.acquire() #在操作时锁住,防止其他线程在同一时间对num变量进行加1,从而确保数据在同一时间确保只有一个线程对它进行更改,不然造成数据不正确
    num += 1
    lock.release() # 释放锁,加完1后释放锁,只有释放之后下一个线程才会开始对num进程操作,不释放的话否则会被该线程一直占用,导致程序不能继续执行下去,一直处于阻塞状态
    time.sleep(0.01)
    print("%s" % num)



lock = threading.RLock() #RLock是允许同时获得好几把锁增加一把锁,如果只需一把锁,那么用threading.Lock()就可以

#启动500百个线程,也就是说这500个线程同时运行runs函数
for i in range(500):
    t = threading.Thread(target=runs,)
    t.start()


本文出自 “运维交流Q群:223843163” 博客,请务必保留此出处http://freshair.blog.51cto.com/8272891/1898705

python多线程之线程锁一(同一时间一个线程获得一把线程锁)

原文:http://freshair.blog.51cto.com/8272891/1898705

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!