Enum orx_pinned_vec::CapacityState

source ·
pub enum CapacityState {
    FixedCapacity(usize),
    DynamicCapacity {
        current_capacity: usize,
        maximum_concurrent_capacity: usize,
    },
}
Expand description

Provides detailed information of capacity state of the pinned vector.

This information contains the current capacity which can be obtained by capacity() method and extends with additional useful information.

  • FixedCapacity variant only provides the current capacity. However, its additional tag informs that this capacity is a hard constraint and the vector cannot grow beyond it.
  • DynamicCapacity variant informs that the vector is capable of allocating and growing its capacity. It provides current_capacity representing the current internal state of the vector. Additionally, maximum_concurrent_capacity is provided. This number represents the maximum number of elements that can safely be pushed to the vector in a concurrent program.

Variants§

§

FixedCapacity(usize)

FixedCapacity variant only provides the current capacity. However, its additional tag informs that this capacity is a hard constraint and the vector cannot grow beyond it.

§

DynamicCapacity

DynamicCapacity variant informs that the vector is capable of allocating and growing its capacity. It provides current_capacity representing the current internal state of the vector. Additionally, maximum_concurrent_capacity is provided. This number represents the maximum number of elements that can safely be pushed to the vector in a concurrent program. This value is often related with the capacity of the container holding meta information about allocations. Note that the dynamic vector can naturally grow beyond this number, this bound is only relevant when the vector is Synced among threads.

Fields

§current_capacity: usize

Capacity of current allocations owned by the vector.

§maximum_concurrent_capacity: usize

Maximum capacity that can safely be reached by the vector in a concurrent program. This value is often related with the capacity of the container holding meta information about allocations. Note that the dynamic vector can naturally grow beyond this number, this bound is only relevant when the vector is Synced among threads.

Implementations§

source§

impl CapacityState

source

pub fn current_capacity(&self) -> usize

Capacity of current allocations owned by the vector.

source

pub fn maximum_concurrent_capacity(&self) -> usize

Maximum capacity that can safely be reached by the vector in a concurrent program. This value is often related with the capacity of the container holding meta information about allocations. Note that the dynamic vector can naturally grow beyond this number, this bound is only relevant when the vector is Synced among threads.

Trait Implementations§

source§

impl Clone for CapacityState

source§

fn clone(&self) -> CapacityState

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 Debug for CapacityState

source§

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

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

impl PartialEq for CapacityState

source§

fn eq(&self, other: &CapacityState) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Copy for CapacityState

source§

impl Eq for CapacityState

source§

impl StructuralPartialEq for CapacityState

Auto Trait Implementations§

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 T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
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> 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.