pub struct Receiver<T: State = TaskCompletion> { /* private fields */ }Expand description
Completion receiver for one-shot tasks
Implements Future directly, allowing direct .await usage on both owned values and mutable references
一次性任务完成通知接收器
直接实现了 Future,允许对拥有的值和可变引用都直接使用 .await
§Examples
§Using default TaskCompletion type
ⓘ
let (notifier, receiver) = Sender::new();
tokio::spawn(async move {
notifier.notify(TaskCompletion::Called);
});
// Two equivalent ways to await:
let result = receiver.await; // Direct await via Future impl
// or
let result = receiver.wait().await; // Explicit wait method§Awaiting on mutable reference
ⓘ
let (notifier, mut receiver) = Sender::new();
tokio::spawn(async move {
notifier.notify(TaskCompletion::Called);
});
// Can also await on &mut receiver
let result = (&mut receiver).await;§Using unit type for simple completion
ⓘ
let (notifier, receiver) = Sender::<()>::new();
tokio::spawn(async move {
// ... do work ...
notifier.notify(()); // Signal completion
});
receiver.await; // Wait for completion§Using custom state
ⓘ
let (notifier, receiver) = Sender::<CustomState>::new();
tokio::spawn(async move {
notifier.notify(CustomState::Success);
});
match receiver.await {
CustomState::Success => println!("Success!"),
CustomState::Failure => println!("Failed"),
CustomState::Timeout => println!("Timed out"),
}Implementations§
Trait Implementations§
Source§impl<T: State> Future for Receiver<T>
Direct Future implementation for Receiver
impl<T: State> Future for Receiver<T>
Direct Future implementation for Receiver
This allows both receiver.await and (&mut receiver).await to work
Optimized implementation:
- Fast path: Immediate return if already completed (no allocation)
- Slow path: Direct waker registration (no Box allocation, just copy two pointers)
- No intermediate future state needed
为 Receiver 直接实现 Future
这允许 receiver.await 和 (&mut receiver).await 都能工作
优化实现:
- 快速路径:如已完成则立即返回(无分配)
- 慢速路径:直接注册 waker(无 Box 分配,只复制两个指针)
- 无需中间 future 状态
impl<T: State> Unpin for Receiver<T>
Auto Trait Implementations§
impl<T> Freeze for Receiver<T>
impl<T = TaskCompletion> !RefUnwindSafe for Receiver<T>
impl<T> Send for Receiver<T>
impl<T> Sync for Receiver<T>
impl<T = TaskCompletion> !UnwindSafe for Receiver<T>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn map<U, F>(self, f: F) -> Map<Self, F>
fn map<U, F>(self, f: F) -> Map<Self, F>
Map this future’s output to a different type, returning a new future of
the resulting type. Read more
Source§fn map_into<U>(self) -> MapInto<Self, U>
fn map_into<U>(self) -> MapInto<Self, U>
Map this future’s output to a different type, returning a new future of
the resulting type. Read more
Source§fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>
fn then<Fut, F>(self, f: F) -> Then<Self, Fut, F>
Chain on a computation for when a future finished, passing the result of
the future to the provided closure
f. Read moreSource§fn left_future<B>(self) -> Either<Self, B>
fn left_future<B>(self) -> Either<Self, B>
Source§fn right_future<A>(self) -> Either<A, Self>
fn right_future<A>(self) -> Either<A, Self>
Source§fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
fn into_stream(self) -> IntoStream<Self>where
Self: Sized,
Convert this future into a single element stream. Read more
Source§fn flatten(self) -> Flatten<Self>
fn flatten(self) -> Flatten<Self>
Flatten the execution of this future when the output of this
future is itself another future. Read more
Source§fn flatten_stream(self) -> FlattenStream<Self>
fn flatten_stream(self) -> FlattenStream<Self>
Flatten the execution of this future when the successful result of this
future is a stream. Read more
Source§fn fuse(self) -> Fuse<Self>where
Self: Sized,
fn fuse(self) -> Fuse<Self>where
Self: Sized,
Fuse a future such that
poll will never again be called once it has
completed. This method can be used to turn any Future into a
FusedFuture. Read moreSource§fn inspect<F>(self, f: F) -> Inspect<Self, F>
fn inspect<F>(self, f: F) -> Inspect<Self, F>
Do something with the output of a future before passing it on. Read more
Source§fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
fn catch_unwind(self) -> CatchUnwind<Self>where
Self: Sized + UnwindSafe,
Catches unwinding panics while polling the future. Read more
Create a cloneable handle to this future where all handles will resolve
to the same result. Read more
Source§fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
fn remote_handle(self) -> (Remote<Self>, RemoteHandle<Self::Output>)where
Self: Sized,
Turn this future into a future that yields
() on completion and sends
its output to another future on a separate task. Read moreSource§fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + Send + 'a>>
fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + Send + 'a>>
Wrap the future in a Box, pinning it. Read more
Source§fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>where
Self: Sized + 'a,
fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>where
Self: Sized + 'a,
Wrap the future in a Box, pinning it. Read more
Source§fn unit_error(self) -> UnitError<Self>where
Self: Sized,
fn unit_error(self) -> UnitError<Self>where
Self: Sized,
Turns a
Future<Output = T> into a
TryFuture<Ok = T, Error = ()>.Source§fn never_error(self) -> NeverError<Self>where
Self: Sized,
fn never_error(self) -> NeverError<Self>where
Self: Sized,
Turns a
Future<Output = T> into a
TryFuture<Ok = T, Error = Never>.Source§impl<F> IntoFuture for Fwhere
F: Future,
impl<F> IntoFuture for Fwhere
F: Future,
Source§type IntoFuture = F
type IntoFuture = F
Which kind of future are we turning this into?
Source§fn into_future(self) -> <F as IntoFuture>::IntoFuture
fn into_future(self) -> <F as IntoFuture>::IntoFuture
Creates a future from a value. Read more