内容简介:arduino多任务库processSchedule在线程中设置延迟的方法
processSchedule 是一个可以应用于 Arduino 平台的 多任务 库,这是个开源项目, 项目地址:https://github.com/wizard97/ArduinoProcessScheduler 在我刚开始使用这个库的时候碰到了一点小问题,我相信很多第一次使用这个库的人都会碰到我这个问题:“就是在使用这个库的时候有没有一种像在loop方法里面使用delay设置延迟的方式?”,答案是否定的,但是有变通的方式,本篇文章就是向大家介绍这种方式的。
我为什么选择使用 processSchedule 库
我先引用一下这个项目介绍的部分内容,然后再来说我选择的理由
Basic
- Control Over How Often a Process Runs (Periodically, Iterations, or as Often as Possible)
- Process Priority Levels (Easily make custom levels as well)
- Dynamically Add/Remove and Enable/Disable Processes
- Interrupt safe (add, disable, destroy, etc.. processes from interrupt routines)
- Process concurrency protection (Process will always be in a valid state)
Advanced
- Spawn new processes from within running processes
- Automatic Process Monitoring Statistics (calculates % CPU time for process)
- Truly object oriented (a Process is its own object)
- Exception Handling (wait what?!)
- Scheduler can automatically interrupt stuck processes
上述引用是这个 多任务 库的一些特点,我把每条都翻译一下 基本的
- 控制Process如何运行(定期,迭代或尽可能多的)
- 支持定义Process优先级(轻松创建自定义级别)
- 动态的添加/删除和允许/禁止一个Process
- 中断安全的(从中断程序增加,禁止,销毁Process等等)
- Process并发保护(Process总是处于有效状态) 高级的
- 允许从运行的Process中产生新的Process
- 自动统计监测Process(每个Process使用的CPU时间的百分比)
- 真正的面向对象(一个Process就是一个对象)
- 异常处理(等什么?!)
- 调度程序可以自动中断卡住的Process 上述的特点是我选择使用这个多任务库的一个原因,最主要的原因就是他是使用面向对象的方式开发,这是一种比较友好的方式,使用更简单。
怎么做?
在开始描述怎么做之前,我默认正在读这篇文章的人都是对这个多任务库有过初步了解通读过这个项目的wiki页面的。如果你还没有进入这个开源项目了解过,可以先去这个项目的主页了解后再回来读这篇文章。
现在开始正式介绍在Process是怎么实现延迟,其实方法也很简单,就是在你想要设置延迟之前先记录一下你当前Process的运行状态,然后调用Process对象的setPeriod(delay_ms)方法重新设置当前Process对象的循环周期,然后return等待下次循环。如果我的描述无法让你理解,那么下面的一个小例子应该能帮助你。
virtual void service() { int lengh=sizeof(tune)/sizeof(tune[0]); noTone(_tonePin); for(int i=state;i<lengh;i++){ tone(_tonePin,tune[i]); state=x+1; /**设置该Process对象新的执行周期, 这样在设置的这个新周期时间之后都会再次调用该对象的service()方法**/ setPeriod(400*durations[i]); return; } state=0; setPeriod(5000); }
对于这种所有过程代码都写在service()方法的案例应该比较容易理解,然而我在实际的应用中可能 会在service()方法中顺序执行多个方法,这些被调用的方法可能会有不同的延迟需要,这样想保存运行状态就会比较复杂了,我们需要给不同的方法定义一种状态,这样当service()方法再次被调用的时候我就能知道该从哪个方法开始执行了,就像下面这个例子一样处理:
//可以先定义一个状态的枚举类,定义出所有的状态 typedef enum processState { STATE_F1, STATE_F2, STATE_F3, ...etc } processState_t; class toneProcess : public process { toneProcess(Scheduler &manager, ProcPriority pr, unsigned int period) : Process(manager, pr, period) { state = STATE_F1; //initialize the current state } //在每次进入到service()方法的时候都检查一下运行状态,确定本次需要执行哪个方法 virtual void service() override { switch(state) { case STATE_F1: function1(); break; case STATE_F2: function2(); break; case STATE_F3: function3(); break; } void function1(){ Serial.println("this is function1"); //start delay setPeriod(500); // Will resume at function 2 in 500ms state = STATE_F2; //state transition to state 2 } } private: processState_t state; };
好了,本文到这里也就可以结束了,以上内容如果有什么说得不清楚或者有错误的地方请大家一定要留言告诉我,我会及时修正。
前几天看到有很多人,特别是 程序员 们使用github的Issues写博客,这让我也很想试一下,所以我也在github上建了一个我的博客项目, 项目地址是:https://github.com/asymt/Blog/issues
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- golang nsq延迟消息存在线程不安全
- RabbitMQ延迟消息的延迟极限是多少?
- RabbitMQ延迟消息的延迟极限是多少?
- 延迟静态绑定——static
- RabbitMQ实现延迟队列
- mybatis 延迟加载
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
创意,未来的工作方式
方军 / 中信出版社 / 2016-11-20 / 58.00元
知识工作者已成过去,创意工作者才是未来 工作的本质是创意 纵观我们身处的世界,除了自然美景,世间或伟大或平凡的事物,几乎都是人观念革新的产物,它们多数是我们在工作过程中群体创意的产物。 从工业时代到知识时代,大多数人通过掌握新知、持续学习,获得社会的认可和回报;但进入以大数据、人工智能、机器人为标志的新时代,单纯的学习已经不能满足社会对人的要求。算法和机器人正在取代人类很多重复性......一起来看看 《创意,未来的工作方式》 这本书的介绍吧!