python threading.Event(tcy)

2024-03-20 10:08
文章标签 python event threading tcy

本文主要是介绍python threading.Event(tcy),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

'''''''''
threading.Event    2018/8/23
--------------------------------------------------------------------------------------
1.class threading.Event实现事件对象的类'''
#     是线程之间通信的最简单机制之一,事件是一个简单的线程同步对象
#     事件处理机制:
#         全局定义Flag标志,set方法设置flag=true,线程不阻塞;
#         clear方法重置flag=false(默认值),wait()方法将阻塞
#     用途:
#         用threading.Event可以使一个线程等待其他线程的通知,我们把这个Event传递到线程对象中,
#         Event默认内置了一个标志,初始值为False
---------------------------------------------------------------------------------------方法:is_set() 仅当内部标志为真时返回true。set()    将内部标志设置为true。# 等待它变为真所有线程都被唤醒。wait()一旦标志为真,调用的线程将不会阻塞。clear()  将内部标志重置false。# 随后,线程调用 wait()将阻塞,直到set()被调用以再次将内部标志设置为true。wait(timeout=None) 一直监听flag,如果没有检测到flag就一直处于阻塞状态# 如输入时内部标志为真,则立即返回。# 否则,阻塞直到另一个线程调用 set()将标志设置为true,或者直到发生可选的超时。# 超时参数:一个浮点数,指定操作超时(秒)# 返回值:# 内部标志在等待调用之前或等待开始之后设置为true时,此方法才返回true,# 除非给定超时且操作超时,否则它将始终返回None。
----------------------------------------------------------------------------------------
2.实例1:
import threading, timedef do(event):print('Start ==> ', time.ctime())event.wait()print('End   ==> ', time.ctime())if __name__ == "__main__":event = threading.Event()  # 创建一个事件event.clear()t1 = threading.Thread(target=do, args=(event,))t1.start()time.sleep(2)event.set()                # 解除阻塞time.sleep(2)print('EndAll==> ', time.ctime())'''
Start ==>  Fri Sep 21 18:08:43 2018
End   ==>  Fri Sep 21 18:08:45 2018
EndAll==>  Fri Sep 21 18:08:47 2018
'''
----------------------------------------------------------------------------------------
# 例2.事件在函数及类中的应用。
#     event.wait(timeout=1)应用;thread.setDaemon(True)的区别
#     类中使用外部变量Threading.Event;也可将此变量初始化在类中;import threading,timetask_1 = threading.Event()
task_2 = threading.Event()
task_3 = threading.Event()def run_sub(name):# 等待事件进入阻塞状态print('1.1.task=[{}]satrt...;线程数=[{}];name={};time={}\n'.format(threading.currentThread().name,threading.active_count(),name,time.ctime()))if name=='Tom':task_1.wait()elif name=='John':task_2.wait()else:task_3.wait(timeout=1)# 收到事件进入运行状态print('1.2.task=[{}]run...  ;线程数=[{}];name={};time={}\n'.format(threading.currentThread().name, threading.active_count(), name,time.ctime()))time.sleep(4)print('1.3.task=[{}]stop    ;线程数=[{}];name={};time={}\n'.format(threading.currentThread().name, threading.active_count(), name,time.ctime()))class MyThread(threading.Thread):def __init__(self, name):threading.Thread.__init__(self)self.task_name = namedef run(self):run_sub(self.task_name)  # 重写run方法#
# 设置线程组
start=time.time()
threads = []
task_names=["Tom","John","Mark"]def test_thread_event():for thread in threads:# thread.setDaemon(True)     #True主线程退出子线程退出(无论是否完成)#false主线程完成等待子线程完成后再退出thread.start()               # 开启线程time.sleep(2)task_2.set()time.sleep(1)task_1.set()print('......主程序结束......!time=%s\n'%(time.time()-start ))
#
#******************************************
for i,name in enumerate(task_names):# 创建新线程# 函数测试用以下语句# threads.append(threading.Thread(target=run_sub, args= (name,)))#添加到线程组#类测试用以下语句threads.append(MyThread(name))   # 添加到线程组test_thread_event()#------------------------------------------
''' 
C:\python37\python.exe C:/python37/Lib/t4.py
1.1.task=[Thread-1]satrt...;线程数=[2];name=Tom;time=Fri Sep 21 19:42:48 20181.1.task=[Thread-2]satrt...;线程数=[3];name=John;time=Fri Sep 21 19:42:48 20181.1.task=[Thread-3]satrt...;线程数=[4];name=Mark;time=Fri Sep 21 19:42:48 20181.2.task=[Thread-3]run...  ;线程数=[4];name=Mark;time=Fri Sep 21 19:42:49 20181.2.task=[Thread-2]run...  ;线程数=[4];name=John;time=Fri Sep 21 19:42:50 2018......主程序结束......!time=3.002171754837036
1.2.task=[Thread-1]run...  ;线程数=[4];name=Tom;time=Fri Sep 21 19:42:51 20181.3.task=[Thread-3]stop    ;线程数=[4];name=Mark;time=Fri Sep 21 19:42:53 20181.3.task=[Thread-2]stop    ;线程数=[3];name=John;time=Fri Sep 21 19:42:54 20181.3.task=[Thread-1]stop    ;线程数=[2];name=Tom;time=Fri Sep 21 19:42:55 2018Process finished with exit code 0'''
----------------------------------------------------------------------------------------
# 例3.事件在两个类之间通过list,event对象传递参数;
#     可以在线程内部及外部控制event对象
#
import time
from threading import Thread, Event
from collections import deque
#
n=100
items = deque()
task1 = Event()
#
class eat_a_meal(Thread):def __init__(self, items, task1,n):Thread.__init__(self)self.items = itemsself.task1 = task1self.n=n#def run(self):while True:self.task1.wait()if  self.items:food = self.items.popleft()if food == 'stop_cook':breakself.n -= 1print("2.2.正在吃1pcs 【%s】...;ThreadName=【%s】;n = 【%d】\n"% (food, self.name, self.n))time.sleep(1)else:if food!='热狗':print("2.1.饭未做好,等待...\n")else:print("3.程序退出...")self.task1.clear()class cook_a_meal(Thread):def __init__(self, items, task1,n):Thread.__init__(self)self.items = itemsself.task1 = task1self.n=nself.cook_category=['包子','馒头','油条','豆浆','鸡蛋','热狗','stop_cook']def run(self):for food in self.cook_category:time.sleep(2)                              #做饭时间self.n+=2self.items.append(food)self.task1.set()                           #解除eat_a_meal 类的阻塞if food!='stop_cook':print("1.制作完成1pcs 【%s】出售中...;ThreadName=【%s】;n = 【%d】\n"% (food, self.name, self.n))
# ******************************************
if __name__ == "__main__":producer = cook_a_meal(items, task1,n)consumer = eat_a_meal(items, task1,n)producer.start()consumer.start()producer.join()consumer.join()'''
# 1.制作完成1pcs 【包子】出售中...;ThreadName=【Thread-1】;n = 【102】
# 2.2.正在吃1pcs 【包子】...;ThreadName=【Thread-2】;n = 【99】
# 2.1.饭未做好,等待...
# 1.制作完成1pcs 【馒头】出售中...;ThreadName=【Thread-1】;n = 【104】
# 2.2.正在吃1pcs 【馒头】...;ThreadName=【Thread-2】;n = 【98】
# 2.1.饭未做好,等待...
# 1.制作完成1pcs 【油条】出售中...;ThreadName=【Thread-1】;n = 【106】
# 2.2.正在吃1pcs 【油条】...;ThreadName=【Thread-2】;n = 【97】
# 2.1.饭未做好,等待...
# 1.制作完成1pcs 【豆浆】出售中...;ThreadName=【Thread-1】;n = 【108】
# 2.2.正在吃1pcs 【豆浆】...;ThreadName=【Thread-2】;n = 【96】
# 2.1.饭未做好,等待...
# 1.制作完成1pcs 【鸡蛋】出售中...;ThreadName=【Thread-1】;n = 【110】
# 2.2.正在吃1pcs 【鸡蛋】...;ThreadName=【Thread-2】;n = 【95】
# 2.1.饭未做好,等待...
# 1.制作完成1pcs 【热狗】出售中...;ThreadName=【Thread-1】;n = 【112】
# 2.2.正在吃1pcs 【热狗】...;ThreadName=【Thread-2】;n = 【94】
# 3.程序退出...
'''
----------------------------------------------------------------------------------------------
# 实例4:利用Event类模拟红绿灯
import threading, timeevent1 = threading.Event()
event2 = threading.Event()def lighter():while True:event1.set()    # 东西绿灯event2.clear()  # 南北红灯print("\33[42;1m [1.east_wast  :GreenLight ...]\033[0m")print("\33[41;1m [2.north_south:RedLight   ...]\033[0m")time.sleep(2)event2.set()    # 东西红灯event1.clear()  # 南北绿灯print('------------------------------------')print("\33[42;1m [2.north_south:GreenLight ...]\033[0m")print("\33[41;1m [1.east_wast  :RedLight   ...]\033[0m")time.sleep(2)# -------------------------------------------------------
def car(name):b1 = 0;b2 = 0;while True:if event1.is_set() and (not b1):  # 判断是否设置了标志位b1 = 1;b2 = 0;print("[1.%s east_wast running  ]" % name)print("[2.%s north_south waiting]" % name)elif not (event1.is_set() and b2):b2 = 1;b1 = 0;print("[2.%s north_south running]" % name)print("[1.%s east_wast waiting  ]" % name)event1.wait()event2.wait()# -------------------------------------------------------
light = threading.Thread(target=lighter, )
light.start()
car = threading.Thread(target=car, args=("JinBei car:",))
car.start()''' 
[1.east_wast  :GreenLight ...]
[2.north_south:RedLight   ...]
[1.JinBei car: east_wast running  ]
[2.JinBei car: north_south waiting]
------------------------------------
[2.JinBei car: north_south running]
[1.JinBei car: east_wast waiting  ]
[2.north_south:GreenLight ...]
[1.east_wast  :RedLight   ...]'''
------------------------------------------------------------------------------

这篇关于python threading.Event(tcy)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/829119

相关文章

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

python 字典d[k]中key不存在的解决方案

《python字典d[k]中key不存在的解决方案》本文主要介绍了在Python中处理字典键不存在时获取默认值的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录defaultdict:处理找不到的键的一个选择特殊方法__missing__有时候为了方便起见,

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主