Receiver

Struct Receiver 

Source
pub struct Receiver<T> { /* private fields */ }
Expand description

The receiving side of a channel.

The receiver can only be called from a single thread.

Implementations§

Source§

impl<T> Receiver<T>

Source

pub fn try_recv(&mut self) -> Result<T, TryRecvError>

Attempts to receive a message immediately.

Source

pub async fn recv(&mut self) -> Result<T, RecvError>

Receives a message asynchronously, if necessary waiting until one becomes available.

Source

pub async fn recv_timeout<D>( &mut self, deadline: D, ) -> Result<T, RecvTimeoutError>
where D: Future<Output = ()>,

Receives a message asynchronously, if necessary waiting until one becomes available or until the deadline elapses.

The deadline is specified as a Future that is expected to resolves to () after some duration, such as a tokio::time::Sleep future.

Source

pub fn close(&self)

Closes the queue.

This prevents any further messages from being sent on the channel. Messages that were already sent can still be received, however, which is why a call to this method should typically be followed by a loop receiving all remaining messages.

For this reason, no counterpart to Sender::is_closed is exposed by the receiver as such method could easily be misused and lead to lost messages. Instead, messages should be received until a RecvError, RecvTimeoutError::Closed or TryRecvError::Closed error is returned.

Trait Implementations§

Source§

impl<T> Debug for Receiver<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T> Drop for Receiver<T>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<T> Stream for Receiver<T>

Source§

type Item = T

Values yielded by the stream.
Source§

fn poll_next( self: Pin<&mut Self>, cx: &mut Context<'_>, ) -> Poll<Option<Self::Item>>

Attempt to pull out the next value of this stream, registering the current task for wakeup if the value is not yet available, and returning None if the stream is exhausted. Read more
Source§

fn size_hint(&self) -> (usize, Option<usize>)

Returns the bounds on the remaining length of the stream. Read more

Auto Trait Implementations§

§

impl<T> Freeze for Receiver<T>

§

impl<T> !RefUnwindSafe for Receiver<T>

§

impl<T> Send for Receiver<T>
where T: Send,

§

impl<T> Sync for Receiver<T>
where T: Send,

§

impl<T> Unpin for Receiver<T>

§

impl<T> !UnwindSafe for Receiver<T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<S, T, E> TryStream for S
where S: Stream<Item = Result<T, E>> + ?Sized,

Source§

type Ok = T

The type of successful values yielded by this future
Source§

type Error = E

The type of failures yielded by this future
Source§

fn try_poll_next( self: Pin<&mut S>, cx: &mut Context<'_>, ) -> Poll<Option<Result<<S as TryStream>::Ok, <S as TryStream>::Error>>>

Poll this TryStream as if it were a Stream. Read more