Struct tauri::async_runtime::Receiver
pub struct Receiver<T> { /* fields omitted */ }
Expand description
Receive values from the associated Sender
.
Instances are created by the channel
function.
This receiver can be turned into a Stream
using ReceiverStream
.
#
ImplementationsReceiver<T>#
impl<T>recv(&'_ mut self) -> Option<T>#
pub async fnReceives the next value for this receiver.
This method returns None
if the channel has been closed and there are no remaining messages in the channel’s buffer. This indicates that no further values can ever be received from this Receiver
. The channel is closed when all senders have been dropped, or when close
is called.
If there are no messages in the channel’s buffer, but the channel has not yet been closed, this method will sleep until a message is sent or the channel is closed. Note that if close
is called, but there are still outstanding Permits
from before it was closed, the channel is not considered closed by recv
until the permits are released.
#
Cancel safetyThis method is cancel safe. If recv
is used as the event in a tokio::select!
statement and some other branch completes first, it is guaranteed that no messages were received on this channel.
#
Examplesuse tokio::sync::mpsc;
#[tokio::main]
async fn main() {
let (tx, mut rx) = mpsc::channel(100);
tokio::spawn(async move {
tx.send("hello").await.unwrap();
});
assert_eq!(Some("hello"), rx.recv().await);
assert_eq!(None, rx.recv().await);
}
Values are buffered:
use tokio::sync::mpsc;
#[tokio::main]
async fn main() {
let (tx, mut rx) = mpsc::channel(100);
tx.send("hello").await.unwrap();
tx.send("world").await.unwrap();
assert_eq!(Some("hello"), rx.recv().await);
assert_eq!(Some("world"), rx.recv().await);
}
blocking_recv(&mut self) -> Option<T>#
pub fnBlocking receive to call outside of asynchronous contexts.
This method returns None
if the channel has been closed and there are no remaining messages in the channel’s buffer. This indicates that no further values can ever be received from this Receiver
. The channel is closed when all senders have been dropped, or when close
is called.
If there are no messages in the channel’s buffer, but the channel has not yet been closed, this method will block until a message is sent or the channel is closed.
This method is intended for use cases where you are sending from asynchronous code to synchronous code, and will work even if the sender is not using blocking_send
to send the message.
Note that if close
is called, but there are still outstanding Permits
from before it was closed, the channel is not considered closed by blocking_recv
until the permits are released.
#
PanicsThis function panics if called within an asynchronous execution context.
#
Examplesuse std::thread;
use tokio::runtime::Runtime;
use tokio::sync::mpsc;
fn main() {
let (tx, mut rx) = mpsc::channel::<u8>(10);
let sync_code = thread::spawn(move || {
assert_eq!(Some(10), rx.blocking_recv());
});
Runtime::new()
.unwrap()
.block_on(async move {
let _ = tx.send(10).await;
});
sync_code.join().unwrap()
}
close(&mut self)#
pub fnCloses the receiving half of a channel without dropping it.
This prevents any further messages from being sent on the channel while still enabling the receiver to drain messages that are buffered. Any outstanding Permit
values will still be able to send messages.
To guarantee that no messages are dropped, after calling close()
, recv()
must be called until None
is returned. If there are outstanding Permit
or OwnedPermit
values, the recv
method will not return None
until those are released.
#
Examplesuse tokio::sync::mpsc;
#[tokio::main]
async fn main() {
let (tx, mut rx) = mpsc::channel(20);
tokio::spawn(async move {
let mut i = 0;
while let Ok(permit) = tx.reserve().await {
permit.send(i);
i += 1;
}
});
rx.close();
while let Some(msg) = rx.recv().await {
println!("got {}", msg);
}
// Channel closed and no messages are lost.
}
poll_recv(&mut self, cx: &mut Context<'_>) -> Poll<Option<T>>#
pub fnPolls to receive the next message on this channel.
This method returns:
Poll::Pending
if no messages are available but the channel is not closed.Poll::Ready(Some(message))
if a message is available.Poll::Ready(None)
if the channel has been closed and all messages sent before it was closed have been received.
When the method returns Poll::Pending
, the Waker
in the provided Context
is scheduled to receive a wakeup when a message is sent on any receiver, or when the channel is closed. Note that on multiple calls to poll_recv
, only the Waker
from the Context
passed to the most recent call is scheduled to receive a wakeup.
#
Trait ImplementationsDebug for Receiver<T>#
impl<T>fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>#
pub fnFormats the value using the given formatter. Read more
Unpin for Receiver<T>#
impl<T>#
Auto Trait ImplementationsRefUnwindSafe for Receiver<T>#
impl<T> \!Send for Receiver<T> where T: Send,#
impl<T>Sync for Receiver<T> where T: Send,#
impl<T>UnwindSafe for Receiver<T>#
impl<T> \!#
Blanket ImplementationsAny for T where T: 'static + ?Sized,[src]#
impl<T>type_id(&self) -> TypeId[src]#
pub fnGets the TypeId
of self
. Read more
Borrow<T> for T where T: ?Sized,[src]#
impl<T>borrow(&self) -> &T[src]#
pub fnImmutably borrows from an owned value. Read more
BorrowMut<T> for T where T: ?Sized,[src]#
impl<T>borrow_mut(&mut self) -> &mutT[src]#
pub fnMutably borrows from an owned value. Read more
From<T> for T[src]#
impl<T>from(t: T) -> T[src]#
pub fnPerforms the conversion.
Into<U> for T where U: From<T>,[src]#
impl<T, U>into(self) -> U[src]#
pub fnPerforms the conversion.
TryFrom<U> for T where U: Into<T>,[src]#
impl<T, U>Error = Infallible#
typeThe type returned in the event of a conversion error.
try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]#
pub fnPerforms the conversion.
TryInto<U> for T where U: TryFrom<T>,[src]#
impl<T, U>Error = <U as TryFrom<T>>::Error#
typeThe type returned in the event of a conversion error.
try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]#
pub fnPerforms the conversion.