mirror of
https://github.com/rust-lang/rust.git
synced 2026-06-02 06:28:20 +03:00
f3fef9a649
In Rust, the strongest guarantee that `&mut` provides is that the memory pointed to is *not aliased*, whereas `&`'s guarantees are much weaker: that the value can be aliased, and may be mutated under proper precautions (interior mutability). Our atomics though use `&mut` for mutation even while creating multiple aliases, so this changes them to use 'interior mutability', mutating through immutable references.
28 lines
977 B
Rust
28 lines
977 B
Rust
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
//! Useful synchronization primitives
|
|
//!
|
|
//! This modules contains useful safe and unsafe synchronization primitives.
|
|
//! Most of the primitives in this module do not provide any sort of locking
|
|
//! and/or blocking at all, but rather provide the necessary tools to build
|
|
//! other types of concurrent primitives.
|
|
|
|
pub mod arc;
|
|
#[cfg(stage0)]
|
|
#[path = "atomics_stage0.rs"]
|
|
pub mod atomics;
|
|
#[cfg(not(stage0))]
|
|
pub mod atomics;
|
|
pub mod deque;
|
|
pub mod mpmc_bounded_queue;
|
|
pub mod mpsc_queue;
|
|
pub mod spsc_queue;
|