SlotmapEntry

Struct SlotmapEntry 

Source
pub struct SlotmapEntry<'a, T> { /* private fields */ }
Expand description

SlotmapEntry is a reference to an element stored in the slotmap.

The SlotmapEntry is created when the element is accessed in the slotmap. It ensures that the element cannot be removed while there is a thread actively accessing it.

§Note

It is the responsibility of the user to ensure that the SlotmapEntry is dropped prior to removing the element from the slotmap. Failure to do so will result in a deadlock, where the erasing method will wait indefinitely for the SlotmapEntry to be dropped.

§Example

use rust_lockless_slotmap::LocklessSlotmap;
use parking_lot::RawRwLock;
 
let slotmap: LocklessSlotmap<usize, RawRwLock> = LocklessSlotmap::new();
let ticket = slotmap.insert(42);
 
{
   let entry = slotmap.get(ticket).unwrap();
   assert_eq!(*entry, 42);
}

Implementations§

Source§

impl<'a, T> SlotmapEntry<'a, T>

Source

pub fn get<'b: 'a>(&'b self) -> &'b T

Get a reference to the element stored in the slotmap.

This reference cannot outlive the protection of the SlotmapEntry. Therefore all access to this element are guaranteed to be safe.

§Returns

A reference to the element stored in the slotmap.

Trait Implementations§

Source§

impl<'a, T> Deref for SlotmapEntry<'a, T>

Source§

type Target = T

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl<'a, T> Drop for SlotmapEntry<'a, T>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<'a, T> Freeze for SlotmapEntry<'a, T>

§

impl<'a, T> RefUnwindSafe for SlotmapEntry<'a, T>
where T: RefUnwindSafe,

§

impl<'a, T> Send for SlotmapEntry<'a, T>
where T: Sync,

§

impl<'a, T> Sync for SlotmapEntry<'a, T>
where T: Sync,

§

impl<'a, T> Unpin for SlotmapEntry<'a, T>

§

impl<'a, T> UnwindSafe for SlotmapEntry<'a, T>
where T: RefUnwindSafe,

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