Struct Receiver
struct Receiver<T> { ... }
The receiving half of a oneshot channel.
Examples
use oneshot;
use thread;
use Duration;
let = channel;
spawn;
println!;
println!;
Receiver cannot be sent between threads if it is receiving non-Send types.
# #![feature(oneshot_channel)]
# use std::sync::oneshot;
# use std::thread;
# use std::ptr;
#
let (sender, receiver) = oneshot::channel();
struct NotSend(*mut ());
sender.send(NotSend(ptr::null_mut()));
thread::spawn(move || {
let reply = receiver.try_recv().unwrap();
});
Implementations
impl<T> Receiver<T>
fn recv(self: Self) -> Result<T, RecvError>Receives the value from the sending end, blocking the calling thread until it gets it.
Can only fail if the corresponding [
Sender<T>] has been dropped.Examples
use oneshot; use thread; use Duration; let = channel; spawn; // This will block until the message arrives. println!;fn try_recv(self: Self) -> Result<T, TryRecvError<T>>Attempts to return a pending value on this receiver without blocking.
Examples
use oneshot; use thread; use Duration; let = channel; spawn; // Keep trying until we get the message, doing other work in the process. loopfn recv_timeout(self: Self, timeout: Duration) -> Result<T, RecvTimeoutError<T>>Attempts to wait for a value on this receiver, returning an error if the corresponding
Senderhalf of this channel has been dropped, or if it waits more thantimeout.Examples
use oneshot; use thread; use Duration; let = channel; spawn; // Wait up to 1 second for the message match receiver.recv_timeoutfn recv_deadline(self: Self, deadline: Instant) -> Result<T, RecvTimeoutError<T>>Attempts to wait for a value on this receiver, returning an error if the corresponding
Senderhalf of this channel has been dropped, or ifdeadlineis reached.Examples
use oneshot; use thread; use ; let = channel; spawn; let deadline = now + from_millis; match receiver.recv_deadline
impl<T> Any for Receiver<T>
fn type_id(self: &Self) -> TypeId
impl<T> Borrow for Receiver<T>
fn borrow(self: &Self) -> &T
impl<T> BorrowMut for Receiver<T>
fn borrow_mut(self: &mut Self) -> &mut T
impl<T> Debug for Receiver<T>
fn fmt(self: &Self, f: &mut fmt::Formatter<'_>) -> fmt::Result
impl<T> Freeze for Receiver<T>
impl<T> From for Receiver<T>
fn from(t: T) -> TReturns the argument unchanged.
impl<T> RefUnwindSafe for Receiver<T>
impl<T> Send for Receiver<T>
impl<T> Sync for Receiver<T>
impl<T> Unpin for Receiver<T>
impl<T> UnwindSafe for Receiver<T>
impl<T, U> Into for Receiver<T>
fn into(self: Self) -> UCalls
U::from(self).That is, this conversion is whatever the implementation of
[From]<T> for Uchooses to do.
impl<T, U> TryFrom for Receiver<T>
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto for Receiver<T>
fn try_into(self: Self) -> Result<U, <U as TryFrom<T>>::Error>