Struct futures_intrusive::channel::shared::GenericReceiver
source · pub struct GenericReceiver<MutexType, T, A>where
MutexType: RawMutex,
A: RingBuf<Item = T>,
T: 'static,{ /* private fields */ }
Expand description
The receiving side of a channel which can be used to exchange values between concurrent tasks.
Tasks can receive values from the channel through the receive
method.
The returned Future will get resolved when a value is sent into the channel.
Implementations
sourceimpl<MutexType, T, A> GenericReceiver<MutexType, T, A>where
MutexType: 'static + RawMutex,
A: 'static + RingBuf<Item = T>,
impl<MutexType, T, A> GenericReceiver<MutexType, T, A>where
MutexType: 'static + RawMutex,
A: 'static + RingBuf<Item = T>,
sourcepub fn receive(&self) -> ChannelReceiveFuture<MutexType, T>ⓘNotable traits for ChannelReceiveFuture<MutexType, T>impl<MutexType, T> Future for ChannelReceiveFuture<MutexType, T> type Output = Option<T>;
pub fn receive(&self) -> ChannelReceiveFuture<MutexType, T>ⓘNotable traits for ChannelReceiveFuture<MutexType, T>impl<MutexType, T> Future for ChannelReceiveFuture<MutexType, T> type Output = Option<T>;
Returns a future that gets fulfilled when a value is written to the channel.
If the channels gets closed, the future will resolve to None
.
sourcepub fn try_receive(&self) -> Result<T, TryReceiveError>
pub fn try_receive(&self) -> Result<T, TryReceiveError>
Attempt to receive form the channel without waiting.
sourcepub fn close(&self) -> CloseStatus
pub fn close(&self) -> CloseStatus
Closes the channel.
All pending future send attempts will fail.
Receive attempts will continue to succeed as long as there are items
stored inside the channel. Further attempts will return None
.
sourcepub fn into_stream(self) -> SharedStream<MutexType, T, A>
pub fn into_stream(self) -> SharedStream<MutexType, T, A>
Returns a stream that will receive values from this channel.
This stream does not yield None
when the channel is empty,
instead it yields None
when it is terminated.