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 FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很