pub unsafe auto trait Sync { }
Expand description
Types for which it is safe to share references between threads.
This trait is automatically implemented when the compiler determines itâs appropriate.
The precise definition is: a type T
is Sync
if and only if &T
is Send
. In other words, if there is no possibility of undefined behavior (including data races) when passing &T
references between threads.
As one would expect, primitive types like u8
and f64
are all Sync
, and so are simple aggregate types containing them, like tuples, structs and enums. More examples of basic Sync
types include âimmutableâ types like &T
, and those with simple inherited mutability, such as Box<T>
, Vec<T>
and most other collection types. (Generic parameters need to be Sync
for their container to be Sync
.)
A somewhat surprising consequence of the definition is that &mut T
is Sync
(if T
is Sync
) even though it seems like that might provide unsynchronized mutation. The trick is that a mutable reference behind a shared reference (that is, & &mut T
) becomes read-only, as if it were a & &T
. Hence there is no risk of a data race.
A shorter overview of how Sync
and Send
relate to referencing:
&T
is Send
if and only if T
is Sync
&mut T
is Send
if and only if T
is Send
&T
and &mut T
are Sync
if and only if T
is Sync
Types that are not Sync
are those that have âinterior mutabilityâ in a non-thread-safe form, such as Cell
and RefCell
. These types allow for mutation of their contents even through an immutable, shared reference. For example the set
method on Cell<T>
takes &self
, so it requires only a shared reference &Cell<T>
. The method performs no synchronization, thus Cell
cannot be Sync
.
Another example of a non-Sync
type is the reference-counting pointer Rc
. Given any reference &Rc<T>
, you can clone a new Rc<T>
, modifying the reference counts in a non-atomic way.
For cases when one does need thread-safe interior mutability, Rust provides atomic data types, as well as explicit locking via sync::Mutex
and sync::RwLock
. These types ensure that any mutation cannot cause data races, hence the types are Sync
. Likewise, sync::Arc
provides a thread-safe analogue of Rc
.
Any types with interior mutability must also use the cell::UnsafeCell
wrapper around the value(s) which can be mutated through a shared reference. Failing to doing this is undefined behavior. For example, transmute
-ing from &T
to &mut T
is invalid.
See the Nomicon for more details about Sync
.
Available on Windows only.
1.63.0 · Source§Available on Windows only.
1.63.0 · Source§Available on Windows only.
1.63.0 · Source§Available on Windows only.
1.10.0 · Source§ 1.6.0 · Source§ 1.0.0 · Source§ 1.34.0 · Source§ 1.34.0 · Source§ 1.34.0 · Source§ 1.34.0 · Source§ 1.0.0 · Source§ 1.34.0 · Source§ 1.34.0 · Source§ 1.34.0 · Source§ 1.34.0 · Source§ 1.0.0 · Source§ 1.36.0 · Source§ 1.44.0 · Source§ 1.44.0 · Source§ Source§ 1.0.0 · Source§ 1.0.0 · Source§ 1.0.0 · Source§ 1.70.0 · Source§ 1.0.0 · Source§ 1.0.0 · Source§ 1.25.0 · Source§NonNull
pointers are not Sync
because the data they reference may be aliased.
ThinBox<T>
is Sync
if T
is Sync
because the data is owned.
T
must be Send
for Mutex
to be Sync
. This ensures that the protected data can be accessed safely from multiple threads without causing data races or other unsafe behavior.
Mutex<T>
provides mutable access to T
to one thread at a time. However, itâs essential for T
to be Send
because itâs not safe for non-Send
structures to be accessed in this manner. For instance, consider Rc
, a non-atomic reference counted smart pointer, which is not Send
. With Rc
, we can have multiple copies pointing to the same heap allocation with a non-atomic reference count. If we were to use Mutex<Rc<_>>
, it would only protect one instance of Rc
from shared access, leaving other copies vulnerable to potential data races.
Also note that it is not necessary for T
to be Sync
as &T
is only made available to one thread at a time if T
is not Sync
.
T
must be Send
for Mutex
to be Sync
. This ensures that the protected data can be accessed safely from multiple threads without causing data races or other unsafe behavior.
Mutex<T>
provides mutable access to T
to one thread at a time. However, itâs essential for T
to be Send
because itâs not safe for non-Send
structures to be accessed in this manner. For instance, consider Rc
, a non-atomic reference counted smart pointer, which is not Send
. With Rc
, we can have multiple copies pointing to the same heap allocation with a non-atomic reference count. If we were to use Mutex<Rc<_>>
, it would only protect one instance of Rc
from shared access, leaving other copies vulnerable to potential data races.
Also note that it is not necessary for T
to be Sync
as &T
is only made available to one thread at a time if T
is not Sync
.
T
must be Sync
for a MutexGuard<T>
to be Sync
because it is possible to get a &T
from &MutexGuard
(via Deref
).
T
must be Sync
for a MutexGuard<T>
to be Sync
because it is possible to get a &T
from &MutexGuard
(via Deref
).
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4