stable_deref_trait

Trait CloneStableDeref

Source
pub unsafe trait CloneStableDeref: StableDeref + Clone { }
Expand description

An unsafe marker trait for types where clones deref to the same address. This has all the requirements of StableDeref, and additionally requires that after calling clone(), both the old and new value deref to the same address. For example, Rc and Arc implement CloneStableDeref, but Box and Vec do not.

Note that a single type should never implement both DerefMut and CloneStableDeref. If it did, this would let you get two mutable references to the same location, by cloning and then calling deref_mut() on both values.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl<'a, T: ?Sized> CloneStableDeref for &'a T

Source§

impl<T: ?Sized> CloneStableDeref for Rc<T>

Source§

impl<T: ?Sized> CloneStableDeref for Arc<T>

Implementors§