[ Python - 12 ] 线程的信号量、标志位及队列
线程的信号量
线程的信号量是同时允许一定数量的线程更改数据,主要作用在于限制线程的并发。
- #!_*_coding:utf-8_*_
- # Author: hkey
- import threading, time
- # 线程的信号量
- sem = threading.BoundedSemaphore(5) # 实例化信号量并限制并发为5个线程
- def run():
- sem.acquire() # 开始
- print('running...', threading.get_ident())
- time.sleep(1)
- sem.release() # 结束
- if __name__ == '__main__':
- for i in range(20):
- t = threading.Thread(target=run)
- t.start()
线程的标志位Events
python线程的事件用于主线程控制其他线程的执行,事件主要提供了三个方法wait、clear、set
- 事件处理的机制:全局定义一个Flag. 使用threading.Event 实现线程间通信 event = threading.Event() 初始值为False
- 如果'Flag'值为False,那么当程序执行event.wait方法时就会阻塞
- 如果'Flag'值为True,那么event.wait方法便不在阻塞
- clear: 将'Flag'设置为False
- set:将'Flag'设置为True
一旦该线程通过wait()方法进入等待状态,直到另一个线程调用Event的set()方法将内置标志设置为True时,该Event会通知所有等待状态的线程恢复运行。
- #!_*_coding:utf-8_*_
- # Author: hkey
- import threading, time
- # 线程的标志位
- # 红绿灯, 灯控制车辆
- event = threading.Event()
- def light():
- n = 0
- while True:
- if n <= 5:
- event.set() # 设置为set, wait就不阻塞 绿灯状态
- print('\33[42;1m green light \33[0m')
- elif 5 < n < 10:
- event.clear() # 将'Flag'设置为False 红灯状态
- print('\33[41;1m red light \33[0m')
- else:
- n = 0
- time.sleep(1)
- n += 1
- def car():
- while True:
- if event.is_set():
- print('cars running...')
- else:
- print('cars stopped...')
- event.wait() # 当使用clear方法将Flag为False,使用wait方法阻塞;当使用set方法将Flag设置为True,则恢复运行
- time.sleep(1)
- t1 = threading.Thread(target=light)
- t2 = threading.Thread(target=car)
- t1.start()
- t2.start()
线程的队列
线程的队列共有三种:
- class queue.Queue(maxsize=0) #先入先出
- class queue.LifoQueue(maxsize=0) # 先入后出
- class queue.PriorityQueue(maxsize=0) #存储数据时可设置优先级的队列
这里主要使用先入先出模式
生产者消费者模型
生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理,直接扔给阻塞队列,消费者不找生产者要数据,而是直接从阻塞队列里取,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力。
- #!_*_coding:utf-8_*_
- # Author: hkey
- import threading, queue, time
- q = queue.Queue()
- def product():
- for i in range(10):
- q.put('包子-%s' %i) # 循环put 10个包子
- print('等待取包子')
- q.join() # 阻塞等待队列被清空
- print('所有包子都被取走了。')
- def consumer():
- while not q.empty(): # empty()方法判断队列是否为空,空为True
- print('吃掉%s' %q.get())
- q.task_done() # 告知这个任务执行完了
- time.sleep(1)
- t1 = threading.Thread(target=product)
- t2 = threading.Thread(target=consumer)
- t1.start()
- t2.start()
[ Python - 12 ] 线程的信号量、标志位及队列的更多相关文章
- Java之【线程通信】--标志位练习
* 写两个线程,一个线程打印1-52,另一个线程答应字母A-Z. * 打印顺序为12A34B56C--5152Z.通过使用线程之间的通信协调关系. 注:分别给两个对象构造一个对象o,数字每打印两个或字 ...
- Java之【线程通信】--标志位练习2
定义一个线程A,输出1 - 10之间的整数,定义一个线程B,逆序输出1 - 10之间的整数,要求线程A和线程B交替输出 方法一:非标志位方法 package Homework; //1 定义一个线程A ...
- Python之线程 3 - 信号量、事件、线程队列与concurrent.futures模块
一 信号量 二 事件 三 条件Condition 四 定时器(了解) 五 线程队列 六 标准模块-concurrent.futures 基本方法 ThreadPoolExecutor的简单使用 Pro ...
- Python学习---线程锁/信号量/条件变量同步/线程池1221
线程锁 问题现象: 多线程情况下,CPU遇到阻塞会进行线程的切换,所以导致执行了tmp-=1的值还未赋值给num=tmp,另一个线程2又开始了tmp -=1,所以导致最后的值重复赋值给了num,所以出 ...
- Day12- Python基础12 线程、GIL、Lock锁、RLock锁、Semaphore锁、同步条件event
http://www.cnblogs.com/yuanchenqi/articles/6248025.html 博客地址 本节内容: 1:进程和线程的说明 2:线程的两种调用方式 3:threadi ...
- Python学习---线程/协程/进程学习 1220【all】
Python学习---线程基础学习 Python学习---线程锁/信号量/条件变量同步1221 Python学习---同步条件event/队列queue1223 Python学习---进程 1225 ...
- Python全栈开发-Day9-线程/GIL/事件/队列
本节内容 进程与线程的概念 Python threading 模块 GIL——global interpreter lock Mutex互斥锁(线程锁) Semaphore信号量 Events事件 Q ...
- python学习笔记12 ----线程、进程
进程和线程的概念 进程和线程是操作系统中两个很重要的概念,对于一般的程序,可能有若干个进程,每一个进程有若干个同时执行的线程.进程是资源管理的最小单位,线程是程序执行的最小单位(线程可共享同一进程里的 ...
- python正则表达式模块re:正则表达式常用字符、常用可选标志位、group与groups、match、search、sub、split,findall、compile、特殊字符转义
本文内容: 正则表达式常用字符. 常用可选标志位. group与groups. match. search. sub. split findall. compile 特殊字符转义 一些现实例子 首发时 ...
随机推荐
- Cassandra 数据库设计
Cassandra 2.* CQL3.1 最近更新:2015-10-30 索引的设计 在Cassandra中经常会发现,索引不够用,不好用,各种不强大. 比如,我关注的人的需求uid + follow ...
- spark1.6.0伪分布式搭建
环境: hadoop2.6.0 jdk1.8 ubuntu 14.04 64位 1 安装scala环境 版本是scala-2.10.6,官网下载地址http://www.scala-lang.org/ ...
- 算法(8)Maximum Product Subarray
题目:在一个数组中找到一个子数组,让子数组的乘积最大,比如[2,3,-2,4]返回6 思路:之前自己想到的思路是对于一个int类型的数组,只要负数的个数是偶数,那么乘积肯定是全局乘就可以了,然后对于负 ...
- password & Encryption
password & Encryption cipher https://dev.tencent.com/login
- Delphi函数详解:全局函数,内部函数,类的成员函数,类的静态方法
1. Delphi中的全局函数 //要点: 需要给其他单元调用, 必须在 interface 声明, 但必须在 uses 区后面 unit Unit1; interface uses Window ...
- HTML5<canvas>标签:简单介绍(0)
<canvas> 标签是 HTML 5 中的新标签,像所有的dom对象一样它有自己本身的属性.方法和事件, 其中就有绘图的方法,js能够调用它来进行绘图 ,最近在研读<html5与c ...
- P2066 机器分配
题目背景 无 题目描述 总公司拥有高效设备M台,准备分给下属的N个分公司.各分公司若获得这些设备,可以为国家提供一定的盈利.问:如何分配这M台设备才能使国家得到的盈利最大?求出最大盈利值.其中M≤15 ...
- 【转】IBatis.Net项目数据库SqlServer迁移至Oracle
转自:http://www.2cto.com/database/201312/265514.html 最近完成了一个(IBatis.Net+MVC)项目的数据库+代码迁移工作,可把我折腾得~~~ IB ...
- Codeforces Round #430 (Div. 2) Vitya and Strange Lesson
D.Vitya and Strange Lesson(字典树) 题意: 给一个长度为\(n\)的非负整数序列,\(m\)次操作,每次先全局异或\(x\),再查询\(mex\) \(1<=n< ...
- BZOJ2818 GCD 【莫比乌斯反演】
2818: Gcd Time Limit: 10 Sec Memory Limit: 256 MB Submit: 6826 Solved: 3013 [Submit][Status][Discuss ...