首页 > 编程语言 > 详细

python多线程之线程锁三(同一时间允许多个线程)

时间:2017-02-17 15:45:55      阅读:231      评论:0      收藏:0      [点我收藏+]
#coding:utf-8
import threading
import time

num = 0 #全局变量

def runs():
    time.sleep(1)
    global num #在函数内部要对全局变量进行更改,需要进行声明
    samp.acquire() #在操作时,获得锁,4个线程都在里边被锁住
    time.sleep(0.001)
    num += 1    #虽然4个线程同时对num进行加1,但在相加的时候,CPU还是一个一个的加
    print("%s" % num)
    samp.release()  # 释放锁

#4个线程分别获得的是4份同样的数据,在相加的时候,CPU还是一个一个的加
samp = threading.BoundedSemaphore(4) #统一时间可以允许多少个线程可以同时去操作,比如这里为4,也就是统一时间可以有4个线程

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


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

python多线程之线程锁三(同一时间允许多个线程)

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

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