Trait consalign::Sync

1.0.0 · source ·
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.

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.

Implementors§

1.26.0 · source§

impl !Sync for Args

1.26.0 · source§

impl !Sync for ArgsOs

1.6.0 · source§

impl Sync for alloc::string::Drain<'_>

source§

impl Sync for AtomicBool

1.34.0 · source§

impl Sync for AtomicI8

1.34.0 · source§

impl Sync for AtomicI16

1.34.0 · source§

impl Sync for AtomicI32

1.34.0 · source§

impl Sync for AtomicI64

source§

impl Sync for AtomicIsize

1.34.0 · source§

impl Sync for AtomicU8

1.34.0 · source§

impl Sync for AtomicU16

1.34.0 · source§

impl Sync for AtomicU32

1.34.0 · source§

impl Sync for AtomicU64

source§

impl Sync for AtomicUsize

1.36.0 · source§

impl Sync for Waker

1.44.0 · source§

impl<'a> Sync for IoSlice<'a>

1.44.0 · source§

impl<'a> Sync for IoSliceMut<'a>

§

impl<'a, 'b, K, Q, V, S, A> Sync for OccupiedEntryRef<'a, 'b, K, Q, V, S, A>where K: Sync, Q: Sync + ?Sized, V: Sync, S: Sync, A: Sync + Allocator + Clone,

§

impl<'a, 'b, K, Q, V, S, A> Sync for OccupiedEntryRef<'a, 'b, K, Q, V, S, A>where K: Sync, Q: Sync + ?Sized, V: Sync, S: Sync, A: Sync + Allocator + Clone,

source§

impl<'a, A, D> Sync for AxisChunksIter<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for AxisChunksIterMut<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for AxisIter<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for AxisIterMut<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for IndexedIter<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for IndexedIterMut<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for ndarray::iterators::Iter<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for ndarray::iterators::IterMut<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for LanesIter<'a, A, D>where A: Sync, D: Sync,

source§

impl<'a, A, D> Sync for LanesIterMut<'a, A, D>where A: Sync, D: Sync,

§

impl<'a, T> Sync for OnceRef<'a, T>where T: Sync,

source§

impl<'a, T, R, C, RStride, CStride> Sync for SliceStorage<'a, T, R, C, RStride, CStride>where T: Sync, R: Dim, C: Dim, RStride: Dim, CStride: Dim,

source§

impl<'a, T, R, C, RStride, CStride> Sync for SliceStorageMut<'a, T, R, C, RStride, CStride>where T: Sync, R: Dim, C: Dim, RStride: Dim, CStride: Dim,

source§

impl<A> Sync for OwnedRepr<A>where A: Sync,

source§

impl<Dyn> Sync for DynMetadata<Dyn>where Dyn: ?Sized,

source§

impl<K, V> Sync for indexmap::map::core::raw::OccupiedEntry<'_, K, V>where K: Sync, V: Sync,

§

impl<K, V, S, A> Sync for OccupiedEntry<'_, K, V, S, A>where K: Sync, V: Sync, S: Sync, A: Sync + Allocator + Clone,

§

impl<K, V, S, A> Sync for OccupiedEntry<'_, K, V, S, A>where K: Sync, V: Sync, S: Sync, A: Sync + Allocator + Clone,

§

impl<K, V, S, A> Sync for RawOccupiedEntryMut<'_, K, V, S, A>where K: Sync, V: Sync, S: Sync, A: Sync + Allocator + Clone,

§

impl<K, V, S, A> Sync for RawOccupiedEntryMut<'_, K, V, S, A>where K: Sync, V: Sync, S: Sync, A: Sync + Allocator + Clone,

source§

impl<S, D> Sync for ArrayBase<S, D>where S: Sync + Data, D: Sync,

ArrayBase is Sync when the storage type is.

source§

impl<T> !Sync for *const Twhere T: ?Sized,

source§

impl<T> !Sync for *mut Twhere T: ?Sized,

source§

impl<T> !Sync for Rc<T>where T: ?Sized,

1.4.0 · source§

impl<T> !Sync for alloc::rc::Weak<T>where T: ?Sized,

source§

impl<T> !Sync for OnceCell<T>

source§

impl<T> !Sync for Cell<T>where T: ?Sized,

source§

impl<T> !Sync for RefCell<T>where T: ?Sized,

source§

impl<T> !Sync for UnsafeCell<T>where T: ?Sized,

1.25.0 · source§

impl<T> !Sync for NonNull<T>where T: ?Sized,

NonNull pointers are not Sync because the data they reference may be aliased.

source§

impl<T> !Sync for Receiver<T>

source§

impl<T> !Sync for Sender<T>

source§

impl<T> Sync for ThinBox<T>where T: Sync + ?Sized,

ThinBox<T> is Sync if T is Sync because the data is owned.

source§

impl<T> Sync for Cursor<'_, T>where T: Sync,

source§

impl<T> Sync for CursorMut<'_, T>where T: Sync,

source§

impl<T> Sync for alloc::collections::linked_list::Iter<'_, T>where T: Sync,

source§

impl<T> Sync for alloc::collections::linked_list::IterMut<'_, T>where T: Sync,

source§

impl<T> Sync for LinkedList<T>where T: Sync,

source§

impl<T> Sync for Arc<T>where T: Sync + Send + ?Sized,

1.4.0 · source§

impl<T> Sync for alloc::sync::Weak<T>where T: Sync + Send + ?Sized,

source§

impl<T> Sync for SyncUnsafeCell<T>where T: Sync + ?Sized,

1.31.0 · source§

impl<T> Sync for ChunksExactMut<'_, T>where T: Sync,

source§

impl<T> Sync for ChunksMut<'_, T>where T: Sync,

source§

impl<T> Sync for core::slice::iter::Iter<'_, T>where T: Sync,

source§

impl<T> Sync for core::slice::iter::IterMut<'_, T>where T: Sync,

1.31.0 · source§

impl<T> Sync for RChunksExactMut<'_, T>where T: Sync,

1.31.0 · source§

impl<T> Sync for RChunksMut<'_, T>where T: Sync,

source§

impl<T> Sync for AtomicPtr<T>

source§

impl<T> Sync for Exclusive<T>where T: ?Sized,

source§

impl<T> Sync for Mutex<T>where T: Send + ?Sized,

1.19.0 · source§

impl<T> Sync for MutexGuard<'_, T>where T: Sync + ?Sized,

source§

impl<T> Sync for OnceLock<T>where T: Sync + Send,

source§

impl<T> Sync for RwLock<T>where T: Send + Sync + ?Sized,

1.23.0 · source§

impl<T> Sync for RwLockReadGuard<'_, T>where T: Sync + ?Sized,

1.23.0 · source§

impl<T> Sync for RwLockWriteGuard<'_, T>where T: Sync + ?Sized,

1.29.0 · source§

impl<T> Sync for JoinHandle<T>

§

impl<T> Sync for OnceBox<T>where T: Sync + Send,

1.6.0 · source§

impl<T, A> Sync for alloc::collections::vec_deque::drain::Drain<'_, T, A>where T: Sync, A: Allocator + Sync,

1.6.0 · source§

impl<T, A> Sync for alloc::vec::drain::Drain<'_, T, A>where T: Sync, A: Sync + Allocator,

source§

impl<T, A> Sync for IntoIter<T, A>where T: Sync, A: Allocator + Sync,

§

impl<T, A> Sync for RawDrain<'_, T, A>where A: Allocator + Copy + Sync, T: Sync,

§

impl<T, A> Sync for RawIntoIter<T, A>where A: Allocator + Clone + Sync, T: Sync,

§

impl<T, A> Sync for RawTable<T, A>where A: Allocator + Clone + Sync, T: Sync,

source§

impl<T, F> Sync for LazyLock<T, F>where T: Sync + Send, F: Send,

§

impl<T, F> Sync for Lazy<T, F>where F: Send, OnceCell<T>: Sync,

Auto implementors§

§

impl !Sync for Vars

§

impl !Sync for VarsOs

§

impl !Sync for Pool

§

impl Sync for Directed

§

impl Sync for ScoreModel

§

impl Sync for TrainType

§

impl Sync for VarError

§

impl Sync for JoinPathsError

§

impl Sync for AlignScores

§

impl Sync for AlignSums

§

impl Sync for AlignfoldHyperparams

§

impl Sync for AlignfoldScores

§

impl Sync for Axis

§

impl Sync for Command

§

impl Sync for DirEntry

§

impl Sync for FastaRecord

§

impl Sync for File

§

impl Sync for FoldScoreSets

§

impl Sync for HAIRPIN_SCORES_SPECIAL

§

impl Sync for Index

§

impl Sync for LoopSums

§

impl Sync for NewAxis

§

impl Sync for Options

§

impl Sync for Output

§

impl Sync for Path

§

impl Sync for RangeInsertScores

§

impl Sync for Record

§

impl Sync for Sequence

§

impl<'a> Sync for SplitPaths<'a>

§

impl<'a, R> Sync for IndexedReaderIterator<'a, R>where R: Sync,

§

impl<B> Sync for Reader<B>where B: Sync,

§

impl<B> Sync for Records<B>where B: Sync,

§

impl<F> Sync for Normal<F>where F: Sync,

§

impl<I: ?Sized> Sync for Dim<I>where I: Sync,

§

impl<Ix> Sync for NodeIndex<Ix>where Ix: Sync,

§

impl<K, V, S, A> Sync for HashMap<K, V, S, A>where A: Sync, K: Sync, S: Sync, V: Sync,

§

impl<N> Sync for Interval<N>where N: Sync,

§

impl<N, E, Ty, Ix> Sync for Graph<N, E, Ty, Ix>where E: Sync, Ix: Sync, N: Sync, Ty: Sync,

§

impl<R> Sync for BufReader<R>where R: Sync,

§

impl<R> Sync for IndexedReader<R>where R: Sync,

§

impl<T> Sync for Align<T>where T: Sync,

§

impl<T> Sync for AlignfoldProbMats<T>where T: Sync,

§

impl<T> Sync for AlignfoldProbMatsAvg<T>where T: Sync,

§

impl<T> Sync for AlignfoldSums<T>where T: Sync,

§

impl<T> Sync for FoldScores<T>where T: Sync,

§

impl<T> Sync for FoldScoresTrained<T>where T: Sync,

§

impl<T> Sync for FoldSums<T>where T: Sync,

§

impl<T> Sync for MatchProbMats<T>where T: Sync,

§

impl<T> Sync for PairAlignfold<T>where T: Sync,

§

impl<T> Sync for TrainDatum<T>where T: Sync,

§

impl<T, S, A> Sync for HashSet<T, S, A>where A: Sync, S: Sync, T: Sync,

§

impl<T, U> Sync for Alignfold<T, U>where T: Sync, U: Sync,

§

impl<T, U> Sync for AlignfoldWrapped<T, U>where T: Sync, U: Sync,

§

impl<W> Sync for BufWriter<W>where W: Sync,

§

impl<W> Sync for Writer<W>where W: Sync,