[][src]Struct ptr::Unique

pub struct Unique<T: ?Sized> { /* fields omitted */ }

A wrapper around a raw non-null *mut T that indicates that the possessor of this wrapper owns the referent. Useful for building abstractions like Box<T>, Vec<T>, String, and HashMap<K, V>.

Unlike *mut T, Unique<T> behaves "as if" it were an instance of T. It implements Send/Sync if T is Send/Sync. It also implies the kind of strong aliasing guarantees an instance of T can expect: the referent of the pointer should not be modified without a unique path to its owning Unique.

If you're uncertain of whether it's correct to use Unique for your purposes, consider using Shared, which has weaker semantics.

Unlike *mut T, the pointer must always be non-null, even if the pointer is never dereferenced. This is so that enums may use this forbidden value as a discriminant -- Option<Unique<T>> has the same size as Unique<T>. However the pointer may still dangle if it isn't dereferenced.

Unlike *mut T, Unique<T> is covariant over T. This should always be correct for any type which upholds Unique's aliasing requirements.

Implementations

impl<T: Sized> Unique<T>[src]

pub const fn empty() -> Self[src]

Creates a new Unique that is dangling, but well-aligned.

This is useful for initializing types which lazily allocate, like Vec::new does.

impl<T: ?Sized> Unique<T>[src]

pub const unsafe fn new_unchecked(ptr: *mut T) -> Self[src]

Creates a new Unique.

Safety

ptr must be non-null.

pub fn new(ptr: *mut T) -> Option<Self>[src]

Creates a new Unique if ptr is non-null.

pub const fn as_ptr(self) -> NonNull<T>[src]

Acquires the underlying *mut pointer.

pub unsafe fn as_ref(&self) -> &T[src]

Dereferences the content.

The resulting lifetime is bound to self so this behaves "as if" it were actually an instance of T that is getting borrowed. If a longer (unbound) lifetime is needed, use &*my_ptr.ptr().

pub unsafe fn as_mut(&mut self) -> &mut T[src]

Mutably dereferences the content.

The resulting lifetime is bound to self so this behaves "as if" it were actually an instance of T that is getting borrowed. If a longer (unbound) lifetime is needed, use &mut *my_ptr.ptr().

Trait Implementations

impl<T: ?Sized> Clone for Unique<T>[src]

impl<S: ?Sized + Unsize<T>, T: ?Sized> CoerceUnsized<Unique<T>> for Unique<S>[src]

impl<T: ?Sized> Copy for Unique<T>[src]

impl<'a, T: ?Sized> From<&'a T> for Unique<T>[src]

impl<'a, T: ?Sized> From<&'a mut T> for Unique<T>[src]

impl<T: ?Sized> From<NonNull<T>> for Unique<T>[src]

impl<T: ?Sized> From<Unique<T>> for Shared<T>[src]

impl<T: ?Sized> Pointer for Unique<T>[src]

impl<T: Send + ?Sized> Send for Unique<T>[src]

Unique pointers are Send if T is Send because the data they reference is unaliased. Note that this aliasing invariant is unenforced by the type system; the abstraction using the Unique must enforce it.

impl<T: Sync + ?Sized> Sync for Unique<T>[src]

Unique pointers are Sync if T is Sync because the data they reference is unaliased. Note that this aliasing invariant is unenforced by the type system; the abstraction using the Unique must enforce it.

Auto Trait Implementations

impl<T: ?Sized> Unpin for Unique<T> where
    T: Unpin

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.