本文主要是介绍rust异步实现(偏应用少理论不头疼版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 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异步实现机制概要
配合资料教程食用更佳
这篇关于rust异步实现(偏应用少理论不头疼版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!