文章目录
- 1 添加依赖
- 2 示例
- 3 tokio异步实现机制概要
参考资料:( 想要进步理解可以看这个 ↓ )
https://www.bilibili.com/video/BV16r4y187P4/?spm_id_from=333.788.recommend_more_video.1&vd_source=20edf767ec72b97832bba2fc3aca50b8
Rust标准库没有实现异步运行时(asynchronous runtime: 可以大致理解成是协调异步任务该先做哪个后做哪个,采取怎样一种事件调度机制的代码),仅仅提供了异步的事件单元Future(什么block_on, await都可以看成是异步的同步化处理);
要想实现应用层真正意义上的异步,除开自己造轮子的大神,我们还需依赖能提供runtime的第三方库,最常用的就是tokio
1 添加依赖
推荐features为full,很多常见功能都需要
[dependencies]
...
tokio = { version = "1.35.1", features = ["full"] }
2 示例
// 模拟多个文件同时读写
use std::{thread::sleep, time::Duration};
#[tokio::main]
async fn main () {
let h1 = tokio::spawn(read_file1());
let h2 = tokio::spawn(read_file2());
let _ = tokio::join!(h1, h2); //都做完了再退出main, 方便显示结果用
}
async fn read_file1 () {
// 5秒输出
sleep(Duration::new(5, 0));
println!("file1 ready")
}
async fn read_file2 () {
// 2秒输出
sleep(Duration::new(2, 0));
println!("file2 ready")
}
打印结果:
file2 ready
file1 ready
------ 补充 ------
3 tokio异步实现机制概要
配合资料教程食用更佳