timer-util是一个极其简单的定时器辅助工具,专门用于生成定时所需的秒数。在我看来有几个优点,请各位关注指正:
- 采用了位运算用来存储定时器的配置(如时,分,秒配置)
- 极致的抽象,只用一个特征来实现各个维度(每月/周的天数、小时、分、秒)的操作
- 采用了build模式,加上简单的api,极容易上手
- 采用enum来规避数值的校验(如秒不应大于60等),减少返回Result
crate,一个简单的案例:
代码语言:javascript复制use log::LevelFilter;use std::time::Duration;use timer_util::*;#[tokio::main]async fn main() -> anyhow::Result<()> {
custom_utils::logger::logger_default("timers", LevelFilter::Trace).unwrap(); // 定时器配置(timer configs):
// every weekday or 1st..10st 15st..25st every month 每周六 或者每月的1号到9号、15号到24号
// every hour 每小时
// 0st/10st/20st/30st/40st/50st minuter 第0/10/20/30/40/50分钟
// 0st/30st second 第0/30秒
let conf = DayHourMinuterSecondConf::default_week_days(WeekDays::default_value(W6))
.conf_month_days(MonthDays::default_range(D1..D10)?.add_range(D15..D25)?)
.build_with_hours(Hours::default_all())
.build_with_minuter(Minuters::default_array(&[M0, M10, M20, M30, M40, M50]))
.build_with_second(Seconds::default_array(&[S0, S30])); // let next_seconds = conf.next()?;
let handle = tokio::spawn(async move { loop { let off_seconds = conf.next().unwrap(); println!("next seconds: {}", off_seconds);
tokio::time::sleep(Duration::from_secs(off_seconds)).await; // println!("{:?}", OffsetDateTime::now_local().unwrap());
}
});
handle.await.unwrap(); Ok(())
}