开发中经常会用到时间相关操作,主要就是用到系统时间、延时操作、定时任务调度等,本文介绍Arduino core for the ESP32中相关的一些功能。

系统时间及应用

系统时间相关方法如下:

unsigned long micros(); //返回微秒为单位系统时间unsigned long millis(); //返回毫秒为单位系统时间void delay(uint32_t); //设置毫秒级延时void delayMicroseconds(uint32_t us); //设置微秒级延时




ESP32 获取时间搓 esp32 定时器_系统时间


上图中微秒时间差稍大于1000us,因为读取时间及串口操作本身有一定耗时;系统时间还可以像下面那样使用:

//该程序用于每一秒或以上时间打印输出一次时间unsigned long previousMillis = 0; //毫秒时间记录const long interval = 1000; //时间间隔void setup(){ Serial.begin(115200); Serial.println();}void loop(){ unsigned long currentMillis = millis(); //读取当前时间 if (currentMillis - previousMillis >= interval) //如果和前次时间大于等于时间间隔 { previousMillis = currentMillis; //更新时间记录 Serial.println(millis()); //打印当前时间 }}


ESP32 获取时间搓 esp32 定时器_ESP32 获取时间搓_02


定时任务调度器Ticker

Ticker可以让你设置以固定时间间隔反复执行某个任务,相比上面的方法,使用Ticker时间上会更加精确,并且代码编写维护也更加方便;

使用步骤

引入头文件#include ;

建立Ticker对象;

编写回调函数(同之前文章中的事件方法一样,这个回调函数中不推荐进行耗时操作);

设置调度时间间隔并启用调度任务;

常用方法

void attach(float seconds, callback_t callback)

void attach(float seconds, void (*callback)(TArg), TArg arg)

设置调度任务,该任务会反复执行,输入参数分别为时间间隔(秒)、回调函数、不大于四字节的数据;

void attach_ms(uint32_t milliseconds, callback_t callback)

void attach_ms(uint32_t milliseconds, void (*callback)(TArg), TArg arg)

设置调度任务,该任务会反复执行,输入参数分别为时间间隔(毫秒)、回调函数、不大于四字节的数据;

void once(float seconds, callback_t callback)

void once(float seconds, void (*callback)(TArg), TArg arg)

设置调度任务,该任务只执行一次,输入参数分别为时间间隔(秒)、回调函数、不大于四字节的数据;

void once_ms(uint32_t milliseconds, callback_t callback)

void once_ms(uint32_t milliseconds, void (*callback)(TArg), TArg arg)

设置调度任务,该任务只执行一次,输入参数分别为时间间隔(毫秒)、回调函数、不大于四字节的数据;

void detach()

停止任务调度;

实例一

#include  //调用Ticker.h库Ticker ticker1; //声明Ticker对象Ticker ticker2; //声明Ticker对象void callback1() //回调函数{ Serial.print(millis()); Serial.println(": callback1 triggered!");}void callback2() //回调函数{ Serial.print(millis()); Serial.println(": callback2 triggered!");}void setup(){ Serial.begin(115200); Serial.println(); ticker1.attach(0.5, callback1); //每0.5秒调用callback1 ticker2.once_ms(2000, callback2); //2000毫秒后调用一次callback2}void loop(){}


ESP32 获取时间搓 esp32 定时器_时间间隔_03


实例二

#include  //调用Ticker.h库Ticker ticker1; //声明Ticker对象Ticker ticker2; //声明Ticker对象void callback2(int data) //回调函数{ Serial.print(millis()); Serial.print(": callback2 data is "); Serial.println(data);}void setup(){ Serial.begin(115200); Serial.println(); ticker1.attach_ms(500, [](){Serial.printf("%d: callback1 triggered!