【Rust】std::sync::mpsc::channel

本文介绍了Rust编程语言中使用std::sync::mpsc实现多生产者、单消费者通道的示例。首先展示了一个简单的单生产者示例,然后扩展到多生产者情况,强调了克隆通道的时机以及在主线程中接收消息的顺序不确定性。通过这两个例子,读者可以理解如何在并发环境中利用mpsc通道进行通信。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mpsc是multiple producer, single consumer的缩写。

单生产者示例

use std::sync::mpsc;
use std::thread;

fn main() {
    // 多生产者,单消费者通道
    let (tx, rx) = mpsc::channel();
    
    // 创建子线程发送数字1
    thread::spawn(move || {
        tx.send(1).unwrap();
    });
    
    // 主线程中接收子线程的消息并输出
    println!("receive {}", rx.recv().unwrap());
}

多生产者示例

use std::sync::mpsc;
use std::thread;

fn main() {
    // 多生产者,单消费者通道
    let (tx, rx) = mpsc::channel();
    let tx2 = tx.clone();     
    
    // 创建线程,发送一个数字1
    thread::spawn(move || {
        tx.send(1).unwrap();
    });
    
    // 创建线程,发送一个数字2
    thread::spawn(move || {
        tx2.send(2).unwrap();
    });
    
    // 在主线程中接收子线程发送的消息并输出
    println!("receive {}", rx.recv().unwrap());
    println!("receive {}", rx.recv().unwrap());
}

注意点:

  1. tx2通过tx1克隆时机,需要在tx 被 move到子线程之前。
  2. rx.recv()调用1次,取1个消息。 2个子线程发送2个消息,需要调用rx.recv() 2次。
  3. 主线程收到2个子线程的消息,顺序是随机的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值