From c89406965ffb4a64936d781c556a2c48855dfbdb Mon Sep 17 00:00:00 2001 From: Hayden Stainsby Date: Thu, 23 Feb 2023 11:04:12 +0100 Subject: [PATCH] sync: document drop behavior for channels (#5497) Some users mentioned that the behavior of a channel when the receivers and/or senders are dropped isn't explicitly documented. This change adds wording to the documentation for each channel in the sync module, explaining under which conditions messages in a channel are dropped with respect to dropping the senders and the receivers. Refs: #5490 --- tokio/src/sync/broadcast.rs | 4 ++++ tokio/src/sync/mpsc/mod.rs | 3 ++- tokio/src/sync/oneshot.rs | 4 ++++ tokio/src/sync/watch.rs | 3 +++ 4 files changed, 13 insertions(+), 1 deletion(-) diff --git a/tokio/src/sync/broadcast.rs b/tokio/src/sync/broadcast.rs index 82239c4119c..6e14ef1e1f4 100644 --- a/tokio/src/sync/broadcast.rs +++ b/tokio/src/sync/broadcast.rs @@ -54,6 +54,10 @@ //! all values retained by the channel, the next call to [`recv`] will return //! with [`RecvError::Closed`]. //! +//! When a [`Receiver`] handle is dropped, any messages not read by the receiver +//! will be marked as read. If this receiver was the only one not to have read +//! that message, the message will be dropped at this point. +//! //! [`Sender`]: crate::sync::broadcast::Sender //! [`Sender::subscribe`]: crate::sync::broadcast::Sender::subscribe //! [`Receiver`]: crate::sync::broadcast::Receiver diff --git a/tokio/src/sync/mpsc/mod.rs b/tokio/src/sync/mpsc/mod.rs index 33889fad766..b2af084b2ae 100644 --- a/tokio/src/sync/mpsc/mod.rs +++ b/tokio/src/sync/mpsc/mod.rs @@ -33,7 +33,8 @@ //! //! If the [`Receiver`] handle is dropped, then messages can no longer //! be read out of the channel. In this case, all further attempts to send will -//! result in an error. +//! result in an error. Additionally, all unread messages will be drained from the +//! channel and dropped. //! //! # Clean Shutdown //! diff --git a/tokio/src/sync/oneshot.rs b/tokio/src/sync/oneshot.rs index a900dbfef24..da64899d095 100644 --- a/tokio/src/sync/oneshot.rs +++ b/tokio/src/sync/oneshot.rs @@ -12,6 +12,10 @@ //! Since the `send` method is not async, it can be used anywhere. This includes //! sending between two runtimes, and using it from non-async code. //! +//! If the [`Receiver`] is closed before receiving a message which has already +//! been sent, the message will remain in the channel until the receiver is +//! dropped, at which point the message will be dropped immediately. +//! //! # Examples //! //! ``` diff --git a/tokio/src/sync/watch.rs b/tokio/src/sync/watch.rs index f8250edd6f3..4341b642999 100644 --- a/tokio/src/sync/watch.rs +++ b/tokio/src/sync/watch.rs @@ -39,6 +39,9 @@ //! when all [`Receiver`] handles have been dropped. This indicates that there //! is no further interest in the values being produced and work can be stopped. //! +//! The value in the channel will not be dropped until the sender and all receivers +//! have been dropped. +//! //! # Thread safety //! //! Both [`Sender`] and [`Receiver`] are thread safe. They can be moved to other