crossbeam::epoch

Struct Owned

Source
pub struct Owned<T>
where T: Pointable + ?Sized,
{ /* private fields */ }
Expand description

An owned heap-allocated object.

This type is very similar to Box<T>.

The pointer must be properly aligned. Since it is aligned, a tag can be stored into the unused least significant bits of the address.

Implementations§

Source§

impl<T> Owned<T>

Source

pub unsafe fn from_raw(raw: *mut T) -> Owned<T>

Returns a new owned pointer pointing to raw.

This function is unsafe because improper use may lead to memory problems. Argument raw must be a valid pointer. Also, a double-free may occur if the function is called twice on the same raw pointer.

§Panics

Panics if raw is not properly aligned.

§Safety

The given raw should have been derived from Owned, and one raw should not be converted back by Owned::from_raw() multiple times.

§Examples
use crossbeam_epoch::Owned;

let o = unsafe { Owned::from_raw(Box::into_raw(Box::new(1234))) };
Source

pub fn into_box(self) -> Box<T>

Converts the owned pointer into a Box.

§Examples
use crossbeam_epoch::Owned;

let o = Owned::new(1234);
let b: Box<i32> = o.into_box();
assert_eq!(*b, 1234);
Source

pub fn new(init: T) -> Owned<T>

Allocates value on the heap and returns a new owned pointer pointing to it.

§Examples
use crossbeam_epoch::Owned;

let o = Owned::new(1234);
Source§

impl<T> Owned<T>
where T: Pointable + ?Sized,

Source

pub fn init(init: <T as Pointable>::Init) -> Owned<T>

Allocates value on the heap and returns a new owned pointer pointing to it.

§Examples
use crossbeam_epoch::Owned;

let o = Owned::<i32>::init(1234);
Source

pub fn into_shared<'g>(self, _: &'g Guard) -> Shared<'g, T>

Converts the owned pointer into a Shared.

§Examples
use crossbeam_epoch::{self as epoch, Owned};

let o = Owned::new(1234);
let guard = &epoch::pin();
let p = o.into_shared(guard);
Source

pub fn tag(&self) -> usize

Returns the tag stored within the pointer.

§Examples
use crossbeam_epoch::Owned;

assert_eq!(Owned::new(1234).tag(), 0);
Source

pub fn with_tag(self, tag: usize) -> Owned<T>

Returns the same pointer, but tagged with tag. tag is truncated to be fit into the unused bits of the pointer to T.

§Examples
use crossbeam_epoch::Owned;

let o = Owned::new(0u64);
assert_eq!(o.tag(), 0);
let o = o.with_tag(2);
assert_eq!(o.tag(), 2);

Trait Implementations§

Source§

impl<T> AsMut<T> for Owned<T>
where T: Pointable + ?Sized,

Source§

fn as_mut(&mut self) -> &mut T

Converts this type into a mutable reference of the (usually inferred) input type.
Source§

impl<T> AsRef<T> for Owned<T>
where T: Pointable + ?Sized,

Source§

fn as_ref(&self) -> &T

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T> Borrow<T> for Owned<T>
where T: Pointable + ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for Owned<T>
where T: Pointable + ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Clone for Owned<T>
where T: Clone,

Source§

fn clone(&self) -> Owned<T>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T> Debug for Owned<T>
where T: Pointable + ?Sized,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<T> Deref for Owned<T>
where T: Pointable + ?Sized,

Source§

type Target = T

The resulting type after dereferencing.
Source§

fn deref(&self) -> &T

Dereferences the value.
Source§

impl<T> DerefMut for Owned<T>
where T: Pointable + ?Sized,

Source§

fn deref_mut(&mut self) -> &mut T

Mutably dereferences the value.
Source§

impl<T> Drop for Owned<T>
where T: Pointable + ?Sized,

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<T> From<Box<T>> for Owned<T>

Source§

fn from(b: Box<T>) -> Owned<T>

Returns a new owned pointer pointing to b.

§Panics

Panics if the pointer (the Box) is not properly aligned.

§Examples
use crossbeam_epoch::Owned;

let o = unsafe { Owned::from_raw(Box::into_raw(Box::new(1234))) };
Source§

impl<T> From<Owned<T>> for Atomic<T>
where T: Pointable + ?Sized,

Source§

fn from(owned: Owned<T>) -> Atomic<T>

Returns a new atomic pointer pointing to owned.

§Examples
use crossbeam_epoch::{Atomic, Owned};

let a = Atomic::<i32>::from(Owned::new(1234));
Source§

impl<T> From<T> for Owned<T>

Source§

fn from(t: T) -> Owned<T>

Converts to this type from the input type.
Source§

impl<T> Pointer<T> for Owned<T>
where T: Pointable + ?Sized,

Source§

unsafe fn from_usize(data: usize) -> Owned<T>

Returns a new pointer pointing to the tagged pointer data.

§Panics

Panics if the data is zero in debug mode.

Source§

fn into_usize(self) -> usize

Returns the machine representation of the pointer.

Auto Trait Implementations§

§

impl<T> Freeze for Owned<T>
where T: ?Sized,

§

impl<T> RefUnwindSafe for Owned<T>
where T: RefUnwindSafe + ?Sized,

§

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

§

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

§

impl<T> Unpin for Owned<T>
where T: ?Sized,

§

impl<T> UnwindSafe for Owned<T>
where T: UnwindSafe + ?Sized,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<!> for T

Source§

fn from(t: !) -> T

Converts to this type from the input type.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 8 bytes