您好,登录后才能下订单哦!
一.python事件Event相关函数介绍
set() — 全局内置标志Flag,将标志Flag 设置为 True,通知在等待状态(wait)的线程恢复运行;
isSet() — 获取标志Flag当前状态,返回True 或者 False;
wait() — 一旦调用,线程将会处于阻塞状态,直到等待其他线程调用set()函数恢复运行;
clear() — 将标志设置为False;
事件event中有一个全局内置标志Flag,值为 True 或者False。使用wait()函数的线程会处于阻塞状态,此时Flag指为False,直到有其他线程调用set()函数让全局标志Flag置为True,其阻塞的线程立刻恢复运行,还可以用isSet()函数检查当前的Flag状态.
假如有这样一个场景:有10个单身狗,对面100米有10个美女,同时起跑,一人一个,自由选择,先到先得…..
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | # !usr/bin/env python # -*- coding:utf-8 _*- # 导入线程模块 import threading
# 创建event事件 eEvent = threading.Event()
def get_girl_friend(id): print("单身狗{}都准备完毕,内置Flag状态:{}.....".format(id,eEvent.isSet())) eEvent.wait() print("单身狗%d告别单身....."%id)
if __name__ == "__main__":
thread_list = list()
for i in range(1,11): # 创建并初始化线程 t = threading.Thread(target=get_girl_friend,args=(i,)) # 启动线程 t.start() # 将线程句柄添加list列表中 thread_list.append(t)
# 所有线程准备完毕,将event内置Flag设置为True,恢复正在阻塞的线程 eEvent.set()
# 遍历列表,阻塞主线程 for t in thread_list: # 阻塞主线程,等待所有子线程结束 t.join()
print("程序结束!") |
输出结果:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | 单身狗1都准备完毕,内置Flag状态:False..... 单身狗2都准备完毕,内置Flag状态:False..... 单身狗3都准备完毕,内置Flag状态:False..... 单身狗4都准备完毕,内置Flag状态:False..... 单身狗5都准备完毕,内置Flag状态:False..... 单身狗6都准备完毕,内置Flag状态:False..... 单身狗7都准备完毕,内置Flag状态:False..... 单身狗8都准备完毕,内置Flag状态:False..... 单身狗9都准备完毕,内置Flag状态:False..... 单身狗10都准备完毕,内置Flag状态:False..... 单身狗5告别单身,内置Flag状态:True..... 单身狗6告别单身,内置Flag状态:True..... 单身狗7告别单身,内置Flag状态:True..... 单身狗1告别单身,内置Flag状态:True..... 单身狗8告别单身,内置Flag状态:True..... 单身狗10告别单身,内置Flag状态:True..... 单身狗4告别单身,内置Flag状态:True..... 单身狗9告别单身,内置Flag状态:True..... 单身狗3告别单身,内置Flag状态:True..... 单身狗2告别单身,内置Flag状态:True..... 程序结束! |
注意互斥锁Lock与事件Event区别,需求不同,使用方式也不同:
互斥锁Lock主要针对多个线程同时操作同一个数据,使用互斥锁可以保证数据正常修改或者访问;
事件Event主要用于唤醒正在阻塞等待状态的线程;
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。