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());
}
注意点:
- tx2通过tx1克隆时机,需要在tx 被 move到子线程之前。
- rx.recv()调用1次,取1个消息。 2个子线程发送2个消息,需要调用rx.recv() 2次。
- 主线程收到2个子线程的消息,顺序是随机的。
本文介绍了Rust编程语言中使用std::sync::mpsc实现多生产者、单消费者通道的示例。首先展示了一个简单的单生产者示例,然后扩展到多生产者情况,强调了克隆通道的时机以及在主线程中接收消息的顺序不确定性。通过这两个例子,读者可以理解如何在并发环境中利用mpsc通道进行通信。
1435

被折叠的 条评论
为什么被折叠?



