SlabArc

Struct SlabArc 

Source
pub struct SlabArc<const N: usize, const SZ: usize> { /* private fields */ }
Expand description

A reference counted, BSlab allocated chunk of bytes.

SlabArcs implement the Deref trait for access to the underlying allocation

§Example

use byte_slab::BSlab;
use std::thread::spawn;

static SLAB: BSlab<4, 128> = BSlab::new();

fn main() {
    // Initialize the byte slab
    SLAB.init().unwrap();

    let mut box_1 = SLAB.alloc_box().unwrap();

    // Fill
    assert_eq!(box_1.len(), 128);
    box_1.iter_mut().enumerate().for_each(|(i, x)| *x = i as u8);

    // Convert the Box into an Arc for sharing
    let arc_1 = box_1.into_arc();

    // And we can cheaply clone by increasing the reference count
    let arc_1_1 = arc_1.clone();

    // We can now send the arc to another thread
    let hdl = spawn(move || {
        arc_1.iter().enumerate().for_each(|(i, x)| assert_eq!(i as u8, *x));
    });

    // ... while still retaining a local handle to the same data
    arc_1_1.iter().enumerate().for_each(|(i, x)| assert_eq!(i as u8, *x));

    hdl.join();
}

Implementations§

Source§

impl<const N: usize, const SZ: usize> SlabArc<N, SZ>

Source

pub fn full_sub_slice_arc(&self) -> SlabSliceArc<N, SZ>

Create a SlabSliceArc from this SlabArc, with a full view of the underlying data

Source

pub fn rerooter_key<'a>(&'a self) -> RerooterKey<'a>

Source

pub fn sub_slice_arc( &self, start: usize, len: usize, ) -> Result<SlabSliceArc<N, SZ>, ()>

Create a SlabSliceArc from this SlabArc, with a partial view of the underlying data.

This function will fail if start and len do not describe a valid region of the SlabArc.

Trait Implementations§

Source§

impl<const N: usize, const SZ: usize> Clone for SlabArc<N, SZ>

Source§

fn clone(&self) -> Self

Returns a duplicate 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<const N: usize, const SZ: usize> Deref for SlabArc<N, SZ>

Source§

type Target = [u8; SZ]

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl<const N: usize, const SZ: usize> Drop for SlabArc<N, SZ>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<const N: usize, const SZ: usize> Freeze for SlabArc<N, SZ>

§

impl<const N: usize, const SZ: usize> !RefUnwindSafe for SlabArc<N, SZ>

§

impl<const N: usize, const SZ: usize> Send for SlabArc<N, SZ>

§

impl<const N: usize, const SZ: usize> Sync for SlabArc<N, SZ>

§

impl<const N: usize, const SZ: usize> Unpin for SlabArc<N, SZ>

§

impl<const N: usize, const SZ: usize> !UnwindSafe for SlabArc<N, SZ>

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, dest: *mut u8)

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