[−][src]Struct tokio::sync::mpsc::UnboundedSender
Send values to the associated UnboundedReceiver
.
Instances are created by the
unbounded_channel
function.
Implementations
impl<T> UnboundedSender<T>
[src]
pub fn send(&self, message: T) -> Result<(), SendError<T>>
[src]
Attempts to send a message on this UnboundedSender
without blocking.
This method is not marked async because sending a message to an unbounded channel
never requires any form of waiting. Because of this, the send
method can be
used in both synchronous and asynchronous code without problems.
If the receive half of the channel is closed, either due to close
being called or the UnboundedReceiver
having been dropped, this
function returns an error. The error includes the value passed to send
.
pub async fn closed(&self)
[src]
Completes when the receiver has dropped.
This allows the producers to get notified when interest in the produced values is canceled and immediately stop doing work.
Examples
use tokio::sync::mpsc; #[tokio::main] async fn main() { let (tx1, rx) = mpsc::unbounded_channel::<()>(); let tx2 = tx1.clone(); let tx3 = tx1.clone(); let tx4 = tx1.clone(); let tx5 = tx1.clone(); tokio::spawn(async move { drop(rx); }); futures::join!( tx1.closed(), tx2.closed(), tx3.closed(), tx4.closed(), tx5.closed() ); }
pub fn is_closed(&self) -> bool
[src]
Checks if the channel has been closed. This happens when the
UnboundedReceiver
is dropped, or when the
UnboundedReceiver::close
method is called.
let (tx, rx) = tokio::sync::mpsc::unbounded_channel::<()>(); assert!(!tx.is_closed()); let tx2 = tx.clone(); assert!(!tx2.is_closed()); drop(rx); assert!(tx.is_closed()); assert!(tx2.is_closed());
pub fn same_channel(&self, other: &Self) -> bool
[src]
Returns true
if senders belong to the same channel.
Examples
let (tx, rx) = tokio::sync::mpsc::unbounded_channel::<()>(); let tx2 = tx.clone(); assert!(tx.same_channel(&tx2)); let (tx3, rx3) = tokio::sync::mpsc::unbounded_channel::<()>(); assert!(!tx3.same_channel(&tx2));
Trait Implementations
impl<T> Clone for UnboundedSender<T>
[src]
fn clone(&self) -> Self
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<T> Debug for UnboundedSender<T>
[src]
Auto Trait Implementations
impl<T> !RefUnwindSafe for UnboundedSender<T>
[src]
impl<T> Send for UnboundedSender<T> where
T: Send,
[src]
T: Send,
impl<T> Sync for UnboundedSender<T> where
T: Send,
[src]
T: Send,
impl<T> Unpin for UnboundedSender<T>
[src]
impl<T> !UnwindSafe for UnboundedSender<T>
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut Tⓘ
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,