【Tokio】异步休眠任务
环境
- Time 2022-01-11
- Rust 1.57.0
- Tokio 1.15.0
概念
参考:https://docs.rs/tokio/latest/tokio/time/index.html
标准库和 Tokio 都提供了线程休眠函数 sleep,标准库的休眠会挂起线程,不做任何事。而 Tokio 的可以放弃执行当前任务去执行其它任务,线程并不会被挂起。
示例
标准库
可以看到先打印 hello tokio
,等待四秒后再次打印,中间间隔了四秒钟。
use std::{io, thread, time::Duration};
use tokio::time;
#[tokio::main(flavor = "current_thread")]
async fn main() -> io::Result<()> {
tokio::spawn(async {
println!("hello tokio");
thread::sleep(Duration::from_secs(4));
});
tokio::spawn(async {
println!("hello tokio");
thread::sleep(Duration::from_secs(4));
});
time::sleep(Duration::from_secs(14)).await;
Ok(())
}
sleep
可以看到同时打印了 hello tokio
。
use std::{io, time::Duration};
use tokio::time;
#[tokio::main(flavor = "current_thread")]
async fn main() -> io::Result<()> {
tokio::spawn(async {
println!("hello tokio");
time::sleep(Duration::from_secs(4)).await;
});
tokio::spawn(async {
println!("hello tokio");
time::sleep(Duration::from_secs(4)).await;
});
time::sleep(Duration::from_secs(14)).await;
Ok(())
}
sleep_util
前面的是休眠多久,还可以设置休眠到什么时候。
use std::{io, time::Duration};
use tokio::time::{self, Instant};
#[tokio::main]
async fn main() -> io::Result<()> {
time::sleep_until(Instant::now() + Duration::from_secs(4)).await;
println!("4s have elapsed");
Ok(())
}
总结
查看了 Tokio 和标准库中线程休眠函数的不同,以及休眠多久和休眠到什么时候。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!