Struct std::sync::mpsc::ReceiverStable [-] [+] [src]

pub struct Receiver<T> {
    // some fields omitted
}

The receiving-half of Rust's channel type. This half can only be owned by one task

Methods

impl<T: Send + 'static> Receiver<T>

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

Attempts to return a pending value on this receiver without blocking

This method will never block the caller in order to wait for data to become available. Instead, this will always return immediately with a possible option of pending data on the channel.

This is useful for a flavor of "optimistic check" before deciding to block on a receiver.

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

Attempt to wait for a value on this receiver, returning an error if the corresponding channel has hung up.

This function will always block the current thread if there is no data available and it's possible for more data to be sent. Once a message is sent to the corresponding Sender, then this receiver will wake up and return that message.

If the corresponding Sender has disconnected, or it disconnects while this call is blocking, this call will wake up and return Err to indicate that no more messages can ever be received on this channel.

fn iter(&self) -> Iter<T>

Returns an iterator that will block waiting for messages, but never panic!. It will return None when the channel has hung up.

Trait Implementations

impl<T: Send + 'static> Send for Receiver<T>

impl<T: Send + 'static> Drop for Receiver<T>

fn drop(&mut self)