[−][src]Struct tokio::sync::mpsc::Sender
Send values to the associated Receiver
.
Instances are created by the channel
function.
To use the Sender
in a poll function, you can use the PollSender
utility.
Implementations
impl<T> Sender<T>
[src]
pub async fn send(&self, value: T) -> Result<(), SendError<T>>
[src]
Sends a value, waiting until there is capacity.
A successful send occurs when it is determined that the other end of the
channel has not hung up already. An unsuccessful send would be one where
the corresponding receiver has already been closed. Note that a return
value of Err
means that the data will never be received, but a return
value of Ok
does not mean that the data will be received. It is
possible for the corresponding receiver to hang up immediately after
this function returns Ok
.
Errors
If the receive half of the channel is closed, either due to close
being called or the Receiver
handle dropping, the function returns
an error. The error includes the value passed to send
.
Examples
In the following example, each call to send
will block until the
previously sent value was received.
use tokio::sync::mpsc; #[tokio::main] async fn main() { let (tx, mut rx) = mpsc::channel(1); tokio::spawn(async move { for i in 0..10 { if let Err(_) = tx.send(i).await { println!("receiver dropped"); return; } } }); while let Some(i) = rx.recv().await { println!("got = {}", i); } }
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::channel::<()>(1); 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() ); println!("Receiver dropped"); }
pub fn try_send(&self, message: T) -> Result<(), TrySendError<T>>
[src]
Attempts to immediately send a message on this Sender
This method differs from send
by returning immediately if the channel's
buffer is full or no receiver is waiting to acquire some data. Compared
with send
, this function has two failure cases instead of one (one for
disconnection, one for a full buffer).
Errors
If the channel capacity has been reached, i.e., the channel has n
buffered values where n
is the argument passed to channel
, then an
error is returned.
If the receive half of the channel is closed, either due to close
being called or the Receiver
handle dropping, the function returns
an error. The error includes the value passed to send
.
Examples
use tokio::sync::mpsc; #[tokio::main] async fn main() { // Create a channel with buffer size 1 let (tx1, mut rx) = mpsc::channel(1); let tx2 = tx1.clone(); tokio::spawn(async move { tx1.send(1).await.unwrap(); tx1.send(2).await.unwrap(); // task waits until the receiver receives a value. }); tokio::spawn(async move { // This will return an error and send // no message if the buffer is full let _ = tx2.try_send(3); }); let mut msg; msg = rx.recv().await.unwrap(); println!("message {} received", msg); msg = rx.recv().await.unwrap(); println!("message {} received", msg); // Third message may have never been sent match rx.recv().await { Some(msg) => println!("message {} received", msg), None => println!("the third message was never sent"), } }
pub async fn send_timeout(
&self,
value: T,
timeout: Duration
) -> Result<(), SendTimeoutError<T>>
[src]
&self,
value: T,
timeout: Duration
) -> Result<(), SendTimeoutError<T>>
Sends a value, waiting until there is capacity, but only for a limited time.
Shares the same success and error conditions as send
, adding one more
condition for an unsuccessful send, which is when the provided timeout has
elapsed, and there is no capacity available.
Errors
If the receive half of the channel is closed, either due to close
being called or the Receiver
having been dropped,
the function returns an error. The error includes the value passed to send
.
Examples
In the following example, each call to send_timeout
will block until the
previously sent value was received, unless the timeout has elapsed.
use tokio::sync::mpsc; use tokio::time::{sleep, Duration}; #[tokio::main] async fn main() { let (tx, mut rx) = mpsc::channel(1); tokio::spawn(async move { for i in 0..10 { if let Err(e) = tx.send_timeout(i, Duration::from_millis(100)).await { println!("send error: #{:?}", e); return; } } }); while let Some(i) = rx.recv().await { println!("got = {}", i); sleep(Duration::from_millis(200)).await; } }
pub fn blocking_send(&self, value: T) -> Result<(), SendError<T>>
[src]
Blocking send to call outside of asynchronous contexts.
This method is intended for use cases where you are sending from
synchronous code to asynchronous code, and will work even if the
receiver is not using blocking_recv
to receive the message.
Panics
This function panics if called within an asynchronous execution context.
Examples
use std::thread; use tokio::runtime::Runtime; use tokio::sync::mpsc; fn main() { let (tx, mut rx) = mpsc::channel::<u8>(1); let sync_code = thread::spawn(move || { tx.blocking_send(10).unwrap(); }); Runtime::new().unwrap().block_on(async move { assert_eq!(Some(10), rx.recv().await); }); sync_code.join().unwrap() }
pub fn is_closed(&self) -> bool
[src]
Checks if the channel has been closed. This happens when the
Receiver
is dropped, or when the Receiver::close
method is
called.
let (tx, rx) = tokio::sync::mpsc::channel::<()>(42); assert!(!tx.is_closed()); let tx2 = tx.clone(); assert!(!tx2.is_closed()); drop(rx); assert!(tx.is_closed()); assert!(tx2.is_closed());
pub async fn reserve(&self) -> Result<Permit<'_, T>, SendError<()>>
[src]
Wait for channel capacity. Once capacity to send one message is available, it is reserved for the caller.
If the channel is full, the function waits for the number of unreceived
messages to become less than the channel capacity. Capacity to send one
message is reserved for the caller. A Permit
is returned to track
the reserved capacity. The send
function on Permit
consumes the
reserved capacity.
Dropping Permit
without sending a message releases the capacity back
to the channel.
Examples
use tokio::sync::mpsc; #[tokio::main] async fn main() { let (tx, mut rx) = mpsc::channel(1); // Reserve capacity let permit = tx.reserve().await.unwrap(); // Trying to send directly on the `tx` will fail due to no // available capacity. assert!(tx.try_send(123).is_err()); // Sending on the permit succeeds permit.send(456); // The value sent on the permit is received assert_eq!(rx.recv().await.unwrap(), 456); }
pub fn try_reserve(&self) -> Result<Permit<'_, T>, TrySendError<()>>
[src]
Try to acquire a slot in the channel without waiting for the slot to become available.
If the channel is full this function will return TrySendError
, otherwise
if there is a slot available it will return a Permit
that will then allow you
to send
on the channel with a guaranteed slot. This function is similar to
reserve
except it does not await for the slot to become available.
Dropping Permit
without sending a message releases the capacity back
to the channel.
Examples
use tokio::sync::mpsc; #[tokio::main] async fn main() { let (tx, mut rx) = mpsc::channel(1); // Reserve capacity let permit = tx.try_reserve().unwrap(); // Trying to send directly on the `tx` will fail due to no // available capacity. assert!(tx.try_send(123).is_err()); // Trying to reserve an additional slot on the `tx` will // fail because there is no capacity. assert!(tx.try_reserve().is_err()); // Sending on the permit succeeds permit.send(456); // The value sent on the permit is received assert_eq!(rx.recv().await.unwrap(), 456); }
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::channel::<()>(1); let tx2 = tx.clone(); assert!(tx.same_channel(&tx2)); let (tx3, rx3) = tokio::sync::mpsc::channel::<()>(1); assert!(!tx3.same_channel(&tx2));
Trait Implementations
impl<T> Clone for Sender<T>
[src]
fn clone(&self) -> Self
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<T> Debug for Sender<T>
[src]
Auto Trait Implementations
impl<T> !RefUnwindSafe for Sender<T>
[src]
impl<T> Send for Sender<T> where
T: Send,
[src]
T: Send,
impl<T> Sync for Sender<T> where
T: Send,
[src]
T: Send,
impl<T> Unpin for Sender<T>
[src]
impl<T> !UnwindSafe for Sender<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>,