【Tokio】单次一对一通道
环境
- Time 2022-01-12
- Rust 1.57.0
- Tokio 1.15.0
概念
参考:https://docs.rs/tokio/latest/tokio/sync/oneshot/index.html
oneshot
可以实现单对单的消息通信,不过只能通信一次。
示例
main.rs
一次跨线程的通信。
use std::thread;
use tokio::sync::oneshot;
#[tokio::main]
async fn main() {
let (tx, rx) = oneshot::channel();
tokio::spawn(async {
println!("{}", thread::current().name().unwrap());
if tx.send("jiangbo").is_err() {
println!("the receiver dropped");
}
});
match rx.await {
Ok(v) => println!("got = {}", v),
Err(_) => println!("the sender dropped"),
}
println!("{}", thread::current().name().unwrap());
}
JoinHandle
如果是任务的最终结果,除了通过消息通信,也可以直接获取。
use std::thread;
#[tokio::main]
async fn main() {
let result = tokio::spawn(async {
println!("{}", thread::current().name().unwrap());
"jiangbo"
});
match result.await {
Ok(v) => println!("got = {}", v),
Err(_) => println!("error"),
}
println!("{}", thread::current().name().unwrap());
}
错误
如果没有发送任何消息就删除了发送者,接收者会异常。
use std::thread;
use tokio::sync::oneshot;
#[tokio::main]
async fn main() {
let (tx, rx) = oneshot::channel::<i32>();
tokio::spawn(async {
println!("{}", thread::current().name().unwrap());
drop(tx);
});
match rx.await {
Ok(_) => unreachable!(),
Err(_) => println!("the sender dropped"),
}
println!("{}", thread::current().name().unwrap());
}
总结
oneshot
用来实现一次单对单的通信,可以跨线程。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!