Struct loom::sync::atomic::AtomicPtr

source ·
pub struct AtomicPtr<T>(/* private fields */);
Expand description

Mock implementation of std::sync::atomic::AtomicPtr.

NOTE: Unlike std::sync::atomic::AtomicPtr, this type has a different in-memory representation than *mut T.

Implementations§

source§

impl<T> AtomicPtr<T>

source

pub fn new(v: *mut T) -> AtomicPtr<T>

Creates a new instance of AtomicPtr.

source

pub unsafe fn unsync_load(&self) -> *mut T

Load the value without any synchronization.

§Safety

An unsynchronized atomic load technically always has undefined behavior. However, if the atomic value is not currently visible by other threads, this should always be equivalent to a non-atomic load of an un-shared *mut T value.

source

pub fn with_mut<R>(&mut self, f: impl FnOnce(&mut *mut T) -> R) -> R

Get access to a mutable reference to the inner value.

source

pub fn into_inner(self) -> *mut T

Consumes the atomic and returns the contained value.

source

pub fn load(&self, order: Ordering) -> *mut T

Loads a value from the pointer.

source

pub fn store(&self, val: *mut T, order: Ordering)

Stores a value into the pointer.

source

pub fn swap(&self, val: *mut T, order: Ordering) -> *mut T

Stores a value into the pointer, returning the previous value.

source

pub fn compare_and_swap( &self, current: *mut T, new: *mut T, order: Ordering ) -> *mut T

Stores a value into the pointer if the current value is the same as the current value.

source

pub fn compare_exchange( &self, current: *mut T, new: *mut T, success: Ordering, failure: Ordering ) -> Result<*mut T, *mut T>

Stores a value into the pointer if the current value is the same as the current value.

source

pub fn compare_exchange_weak( &self, current: *mut T, new: *mut T, success: Ordering, failure: Ordering ) -> Result<*mut T, *mut T>

Stores a value into the atomic if the current value is the same as the current value.

source

pub fn fetch_update<F>( &self, set_order: Ordering, fetch_order: Ordering, f: F ) -> Result<*mut T, *mut T>
where F: FnMut(*mut T) -> Option<*mut T>,

Fetches the value, and applies a function to it that returns an optional new value. Returns a Result of Ok(previous_value) if the function returned Some(_), else Err(previous_value).

Trait Implementations§

source§

impl<T> Debug for AtomicPtr<T>

source§

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

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

impl<T> Default for AtomicPtr<T>

source§

fn default() -> AtomicPtr<T>

Returns the “default value” for a type. Read more
source§

impl<T> From<*mut T> for AtomicPtr<T>

source§

fn from(p: *mut T) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl<T> Freeze for AtomicPtr<T>

§

impl<T> RefUnwindSafe for AtomicPtr<T>

§

impl<T> Send for AtomicPtr<T>

§

impl<T> Sync for AtomicPtr<T>

§

impl<T> Unpin for AtomicPtr<T>

§

impl<T> UnwindSafe for AtomicPtr<T>

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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more