rust异步实现(偏应用少理论不头疼版)

发布时间:2024年01月11日

参考资料:( 想要进步理解可以看这个 ↓ )
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异步实现机制概要

配合资料教程食用更佳
在这里插入图片描述

文章来源:https://blog.csdn.net/weixin_44539199/article/details/135531785
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。