Struct mz_persist_client::internal::cache::lru::Lru

source ·
pub struct Lru<K, V> {
    evict_fn: Box<dyn Fn(K, V, usize) + Send>,
    capacity: Weight,
    next_time: Time,
    entries: HashMap<K, (V, Weight, Time)>,
    by_time: BTreeMap<Time, K>,
    total_weight: Weight,
}
Expand description

A weighted cache, evicting the least recently used entries.

This is reimplemented here, instead of using an existing crate, because existing options seem to either not support weights or they use unsafe.

Fields§

§evict_fn: Box<dyn Fn(K, V, usize) + Send>§capacity: Weight§next_time: Time§entries: HashMap<K, (V, Weight, Time)>§by_time: BTreeMap<Time, K>§total_weight: Weight

Implementations§

source§

impl<K: Hash + Eq + Clone, V> Lru<K, V>

source

pub fn new<F>(capacity: usize, evict_fn: F) -> Self
where F: Fn(K, V, usize) + Send + 'static,

Returns a new Lru with the requested configuration.

evict_fn is called for every entry evicted by the least recently used policy. It is not called for entries replaced by the same key in insert nor entries explictly removed by remove.

source

pub fn capacity(&self) -> usize

Returns the capacity of the cache.

source

pub fn entry_count(&self) -> usize

Returns the total number of entries in the cache.

source

pub fn entry_weight(&self) -> usize

Returns the sum of weights of entries in the cache.

source

pub fn update_capacity(&mut self, capacity: usize)

Changes the weighted capacity of the cache, evicting as necessary if the new value is smaller.

source

pub fn get<Q>(&mut self, key: &Q) -> Option<(&K, &V)>
where K: Borrow<Q>, Q: Hash + Eq + ?Sized,

Returns a reference to entry with the given key, if present, marking it as most recently used.

source

pub fn insert(&mut self, key: K, val: V, weight: usize)

Inserts the given key and value into the cache, marking it as most recently used.

If the key already exists in the cache, the existing value and weight are first removed.

source

pub fn remove<Q>(&mut self, k: &Q) -> Option<(K, V, usize)>
where K: Borrow<Q>, Q: Hash + Eq + ?Sized,

Removes the entry with the given key from the cache, if present.

Returns None if the entry was not in the cache.

source

pub(crate) fn iter(&self) -> impl Iterator<Item = (&K, &V, usize)>

Returns an iterator over the entries in the cache in order from most recently used to least.

source

fn insert_not_exists(&mut self, key: K, val: V, weight: Weight)

source

fn remove_exists(&mut self, time: Time) -> (K, V, Weight)

source

fn resize(&mut self)

Trait Implementations§

source§

impl<K: Debug, V> Debug for Lru<K, V>

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<K, V> Freeze for Lru<K, V>

§

impl<K, V> !RefUnwindSafe for Lru<K, V>

§

impl<K, V> Send for Lru<K, V>
where K: Send, V: Send,

§

impl<K, V> !Sync for Lru<K, V>

§

impl<K, V> Unpin for Lru<K, V>
where K: Unpin, V: Unpin,

§

impl<K, V> !UnwindSafe for Lru<K, V>

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, U> CastInto<U> for T
where U: CastFrom<T>,

source§

fn cast_into(self) -> U

Performs the cast.
source§

impl<T> CopyAs<T> for T

source§

fn copy_as(self) -> T

source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

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, R> ProtoType<R> for P
where R: RustType<P>,

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<'a, S, T> Semigroup<&'a S> for T
where T: Semigroup<S>,

source§

fn plus_equals(&mut self, rhs: &&'a S)

The method of std::ops::AddAssign, for types that do not implement AddAssign.
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.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more