share-to-threadsafe - The Rust RFC Book (original) (raw)
The Rust RFC Book
- Start Date: 2014-06-15
- RFC PR #: rust-lang/rfcs#123
- Rust Issue #: rust-lang/rust#16281
Summary
Rename the Share
trait to Sync
Motivation
With interior mutability, the name “immutable pointer” for a value of type &T
is not quite accurate. Instead, the term “shared reference” is becoming popular to reference values of type &T
. The usage of the term “shared” is in conflict with the Share
trait, which is intended for types which can be safely shared concurrently with a shared reference.
Detailed design
Rename the Share
trait in std::kinds
to Sync
. Documentation would refer to &T
as a shared reference and the notion of “shared” would simply mean “many references” while Sync
implies that it is safe to share among many threads.
Drawbacks
The name Sync
may invoke conceptions of “synchronized” from languages such as Java where locks are used, rather than meaning “safe to access in a shared fashion across tasks”.
Alternatives
As any bikeshed, there are a number of other names which could be possible for this trait:
Concurrent
Synchronized
Threadsafe
Parallel
Threaded
Atomic
DataRaceFree
ConcurrentlySharable
Unresolved questions
None.