Struct tantivy_stacker::SharedArenaHashMap

source ·
pub struct SharedArenaHashMap { /* private fields */ }
Expand description

Customized HashMap with &[u8] keys

Its main particularity is that rather than storing its keys in the heap, keys are stored in a memory arena inline with the values.

The quirky API has the benefit of avoiding the computation of the hash of the key twice, or copying the key as long as there is no insert.

SharedArenaHashMap is like ArenaHashMap but gets the memory arena passed as an argument to the methods. So one MemoryArena can be shared with multiple SharedArenaHashMap.

Implementations§

source§

impl SharedArenaHashMap

source

pub fn with_capacity(table_size: usize) -> SharedArenaHashMap

source

pub fn mem_usage(&self) -> usize

source

pub fn is_empty(&self) -> bool

source

pub fn len(&self) -> usize

source

pub fn iter<'a>(&'a self, memory_arena: &'a MemoryArena) -> Iter<'_>

source

pub fn get<V>(&self, key: &[u8], memory_arena: &MemoryArena) -> Option<V>
where V: Copy + 'static,

Get a value associated to a key.

source

pub fn mutate_or_create<V>( &mut self, key: &[u8], memory_arena: &mut MemoryArena, updater: impl FnMut(Option<V>) -> V ) -> V
where V: Copy + 'static,

update create a new entry for a given key if it does not exist or updates the existing entry.

The actual logic for this update is define in the updater argument.

If the key is not present, updater will receive None and will be in charge of returning a default value. If the key already as an associated value, then it will be passed Some(previous_value).

The key will be truncated to u16::MAX bytes.

Trait Implementations§

source§

impl Default for SharedArenaHashMap

source§

fn default() -> Self

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

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