博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RT-Thread中的事件机制-多次发送同一个事件等同于一次触发
阅读量:4297 次
发布时间:2019-05-27

本文共 625 字,大约阅读时间需要 2 分钟。

事件是信号量的扩展,在很多情况下可以用事件代替信号量的同步,事件可以一对一、一对多、多对一、多对多。

一个线程可等待多个事件的触发:可以是其中任意一个事件唤醒线程进行事件处理的

操作;也可以是几个事件都到达后才唤醒线程进行后续的处理;同样,事件也可以是多个线
程同步多个事件,这种多个事件的集合可以用一个32位无符号整型变量来表示,变量的每一
位代表一个事件,线程通过“逻辑与”或“逻辑或”与一个或多个事件建立关联,形成一个
事件集。事件的“逻辑或”也称为是独立型同步,指的是线程与任何事件之一发生同步;事
件“逻辑与”也称为是关联型同步,指的是线程与若干事件都发生同步。
RT-Thread定义的事件有以下特点:
• 事件只与线程相关,事件间相互独立:每个线程拥有32个事件标志,采用一个32 bit
无符号整型数进行记录,每一个bit代表一个事件。若干个事件构成一个事件集;
• 事件仅用于同步,不提供数据传输功能;
• 事件无排队性,即多次向线程发送同一事件(如果线程还未来得及读走),其效果等同
于只发送一次。
在RT-Thread实现中,每个线程都拥有一个事件信息标记,它有三个属性,分别是
RT_EVENT_FLAG_AND(逻辑与),RT_EVENT_FLAG_OR(逻辑或)以及RT_EVENT_FLAG_CLEAR
(清除标记)。当线程等待事件同步时,可以通过32个事件标志和这个事件信息标记来判断
当前接收的事件是否满足同步条件。
 

转载地址:http://jrcws.baihongyu.com/

你可能感兴趣的文章
设计模式20_观察者
查看>>
vnpy学习10_常见坑
查看>>
vnpy学习10_常见坑02
查看>>
用时三个月,终于把所有的Python库全部整理了!拿去别客气!
查看>>
pd.stats.ols.MovingOLS以及替代
查看>>
vnpy学习11_增加测试评估指标
查看>>
资金流入流出计算方法
查看>>
海龟交易法则07_如何衡量风险
查看>>
海龟交易法则08_风险与资金管理
查看>>
海龟交易法则09_海龟式积木
查看>>
海龟交易法则10_通用积木
查看>>
海龟交易法则14_掌控心魔
查看>>
海龟交易法则15_万事俱备
查看>>
海龟交易法则16_附原版海龟交易法则
查看>>
克罗谈投资策略01_期货交易中的墨菲法则
查看>>
克罗谈投资策略02_赢家和输家
查看>>
克罗谈投资策略03_你所期望的赌博方式
查看>>
克罗谈投资策略04_感觉与现实
查看>>
通向财务自由之路01_导读
查看>>
通向财务自由之路02_成功的决定因素:你
查看>>