pub struct Receiver<T> { /* private fields */ }Expand description
The receiving end of a channel.
Note: Cloning the receiver does not turn this channel into a broadcast channel. Each message will only be received by a single receiver. This is useful for implementing work stealing for concurrent programs.
Implementations§
source§impl<T> Receiver<T>
impl<T> Receiver<T>
sourcepub fn try_recv(&self) -> Result<T, TryRecvError>
pub fn try_recv(&self) -> Result<T, TryRecvError>
Attempts to receive a value from the channel associated with this receiver, returning an error if the channel is empty or if all senders have been dropped.
This method will block until a value is available on the channel, or until the channel is empty or all senders have been dropped.
sourcepub fn recv_async(&self) -> RecvFuture<T> ⓘ
pub fn recv_async(&self) -> RecvFuture<T> ⓘ
Asynchronously receive a value from the channel, returning an error if all senders have been dropped. If the channel is empty, the returned future will yield to the async runtime.
This method returns a future that will be resolved with the value received from the channel, or with an error if the channel is closed.
sourcepub fn recv(&self) -> Result<T, RecvError>
pub fn recv(&self) -> Result<T, RecvError>
Wait for an incoming value from the channel associated with this receiver. If all senders have been dropped and there are no more messages in the channel, this method will return an error.
sourcepub fn recv_timeout(&self, timeout: Duration) -> Result<T, RecvTimeoutError>
pub fn recv_timeout(&self, timeout: Duration) -> Result<T, RecvTimeoutError>
Receives a value from the channel associated with this receiver, blocking the current thread until a value is available or the timeout expires.
sourcepub fn recv_deadline(&self, deadline: Instant) -> Result<T, RecvTimeoutError>
pub fn recv_deadline(&self, deadline: Instant) -> Result<T, RecvTimeoutError>
Receives a value from the channel associated with this receiver, blocking the current thread until a value is available or the deadline has passed.
sourcepub fn drain(&self) -> Drain<'_, T> ⓘ
pub fn drain(&self) -> Drain<'_, T> ⓘ
Take all msgs currently sitting in the channel and produce an iterator over them. Unlike
try_iter, the iterator will not attempt to fetch any more values from the channel once
the function has been called.
sourcepub fn iter(&self) -> Iter<'_, T> ⓘ
pub fn iter(&self) -> Iter<'_, T> ⓘ
Returns a blocking iterator over the values received on the channel. The iterator will finish iteration when all senders have been dropped.
sourcepub fn try_iter(&self) -> TryIter<'_, T> ⓘ
pub fn try_iter(&self) -> TryIter<'_, T> ⓘ
An iterator over the values received on the channel that finishes iteration when all senders have been dropped or the channel is empty.
This iterator is non-blocking, meaning that it will not wait for the next value to be available
if there is not one already. If there is no value available, the iterator will return None.
sourcepub fn same_channel(&self, other: &Receiver<T>) -> bool
pub fn same_channel(&self, other: &Receiver<T>) -> bool
Returns true if the two receivers belong to the same channel, and false otherwise.
sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Returns the number of messages currently in the channel.
This function is useful for determining how many messages are waiting to be processed by consumers, or for implementing backpressure mechanisms.
sourcepub fn capacity(&self) -> Option<usize>
pub fn capacity(&self) -> Option<usize>
Returns the capacity of the channel, if it is bounded. Otherwise, returns None.
sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Returns true if the channel is empty.
Note: Zero-capacity channels are always empty.
sourcepub fn is_full(&self) -> bool
pub fn is_full(&self) -> bool
Returns true if the channel is full.
Note: Zero-capacity channels are always full.
Trait Implementations§
source§impl<T> Clone for Receiver<T>
impl<T> Clone for Receiver<T>
source§fn clone(&self) -> Self
fn clone(&self) -> Self
Clone this receiver. Receiver acts as a handle to the ending a channel. Remaining
channel contents will only be cleaned up when all senders and the receiver have been
dropped.
Note: Cloning the receiver does not turn this channel into a broadcast channel. Each message will only be received by a single receiver. This is useful for implementing work stealing for concurrent programs.
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more