Struct string_interner::backend::BucketBackend[][src]

pub struct BucketBackend<S> { /* fields omitted */ }
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

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

Rating varies between bad, ok and good.

ScenarioRating
Fillgood
Resolveok
Allocationsgood
Footprintok
Supports get_or_intern_staticyes
Send + Syncyes

Trait Implementations

Creates a new backend for the given capacity. Read more

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

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

Shrink backend capacity to fit interned symbols exactly.

Resolves the given symbol to its original string contents.

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

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

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

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

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.

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

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Performs the conversion.

Performs the conversion.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.