前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[大家的项目] timer-util

[大家的项目] timer-util

作者头像
MikeLoveRust
发布2022-06-10 15:14:28
9670
发布2022-06-10 15:14:28
举报
文章被收录于专栏:Rust语言学习交流

timer-util是一个极其简单的定时器辅助工具,专门用于生成定时所需的秒数。在我看来有几个优点,请各位关注指正:

  1. 采用了位运算用来存储定时器的配置(如时,分,秒配置)
  2. 极致的抽象,只用一个特征来实现各个维度(每月/周的天数、小时、分、秒)的操作
  3. 采用了build模式,加上简单的api,极容易上手
  4. 采用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(())
}
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-06-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Rust语言学习交流 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档