pub struct BucketBackend<S = DefaultSymbol> { /* private fields */ }
Expand description

An interner backend that reduces memory allocations by using string buckets.

§Note

Implementation inspired by matklad’s blog post that can be found here: https://matklad.github.io/2020/03/22/fast-simple-rust-interner.html

§Usage Hint

Use when deallocations or copy overhead is costly or when interning of static strings is especially common.

§Usage

  • Fill: Efficiency of filling an empty string interner.
  • Resolve: Efficiency of interned string look-up given a symbol.
  • Allocations: The number of allocations performed by the backend.
  • Footprint: The total heap memory consumed by the backend.
  • Contiguous: True if the returned symbols have contiguous values.

Rating varies between bad, ok, good and best.

ScenarioRating
Fillgood
Resolveok
Allocationsgood
Footprintok
Supports get_or_intern_staticyes
Send + Syncyes
Contiguousyes

Trait Implementations§

source§

impl<S> Backend for BucketBackend<S>
where S: Symbol,

§

type Symbol = S

The symbol used by the string interner backend.
source§

fn with_capacity(cap: usize) -> Self

Creates a new backend for the given capacity. Read more
source§

fn intern(&mut self, string: &str) -> Self::Symbol

Interns the given string and returns its interned ref and symbol. Read more
source§

fn intern_static(&mut self, string: &'static str) -> Self::Symbol

Interns the given static string and returns its interned ref and symbol. Read more
source§

fn shrink_to_fit(&mut self)

Shrink backend capacity to fit interned symbols exactly.
source§

fn resolve(&self, symbol: Self::Symbol) -> Option<&str>

Resolves the given symbol to its original string contents.
source§

unsafe fn resolve_unchecked(&self, symbol: Self::Symbol) -> &str

Resolves the given symbol to its original string contents. Read more
source§

impl<S> Clone for BucketBackend<S>

source§

fn clone(&self) -> Self

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<S: Debug> Debug for BucketBackend<S>

source§

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

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

impl<S> Default for BucketBackend<S>

source§

fn default() -> Self

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

impl<'a, S> IntoIterator for &'a BucketBackend<S>
where S: Symbol,

§

type Item = (S, &'a str)

The type of the elements being iterated over.
§

type IntoIter = Iter<'a, S>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
source§

impl<S> PartialEq for BucketBackend<S>
where S: Symbol,

source§

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

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

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

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

impl<S> Eq for BucketBackend<S>
where S: Symbol,

source§

impl<S> Send for BucketBackend<S>
where S: Symbol,

§Safety

The bucket backend requires a manual Send impl because it is self referential. When cloning a bucket backend a deep clone is performed and all references to itself are updated for the clone.

source§

impl<S> Sync for BucketBackend<S>
where S: Symbol,

§Safety

The bucket backend requires a manual Send impl because it is self referential. Those references won’t escape its own scope and also the bucket backend has no interior mutability.

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. 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,

§

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

§

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.