您当前的位置 :首页 > 学习资料 > rust 实现协程池
投稿

rust 实现协程池

2023-02-13 00:35:56 来源: 作者: 责任编辑:cncml


use crossbeam_channel::{Receiver, bounded};
use tokio::time::{Duration, delay_for};
 
#[tokio::main]
async fn main() {
    let (s, r) = bounded(10);
 
    for i in 0..100 {
        s.send(i).unwrap();
        let rx = r.clone();
        tokio::task::spawn(async move {
            handle(i, rx).await;
        });
    }
 
    delay_for(Duration::from_secs(10)).await;
}
 
async fn handle(i: i32, rx: Receiver<i32>) {
    let _d = defer::defer(|| {
        println!("{} been defer", i);
        if let Err(err) = rx.recv() {
            println!("err : {:?}", err);
        }
    });
 
    delay_for(Duration::from_secs(1)).await;
    println!("{} been excute", i);
}

使用 channel 做数量控制, defer 来保证 所有 消息被释放

 
文章来源: 责任编辑:cncml
版权声明:
1、本主题所有言论和图片纯属会员个人意见,与本网站立场无关
2、本站所有主题由该文章作者发表,该文章作者与享有文章相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该文章作者和的同意
4、文章作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、管理员和版主有权不事先通知发贴者而删除本文
不良信息举报信箱 新闻热线:18733599993 技术服务:18733599993 网上投稿
关于本站 | 广告服务 | 免责申明 | 招聘信息 | 联系我们
在线网 版权所有 Copyright(C)2005-2025