Cache

Struct Cache 

Source
pub struct Cache { /* private fields */ }
Expand description

A thread-safe Least Recently Used (LRU) cache.

This struct wraps an LruCache in a Mutex to allow concurrent access from multiple threads. It maps canonicalised JSON strings to their corresponding database IDs. It also tracks hit and miss statistics.

Implementations§

Source§

impl Cache

Source

pub fn new(capacity: usize) -> Self

Creates a new Cache with the specified capacity.

§Arguments
  • capacity - The maximum number of items the cache can hold. Minimum capacity is 1.
Source

pub fn get(&self, key: &str) -> Option<i32>

Retrieves an ID from the cache if it exists.

§Arguments
  • key - The canonicalised JSON string key.
§Returns

Some(i32) if the key exists, None otherwise. Returns None if the cache mutex is poisoned (treated as cache miss).

Source

pub fn put(&self, key: String, value: i32)

Inserts a key-value pair into the cache.

§Arguments
  • key - The canonicalised JSON string key.
  • value - The database ID associated with the key.

If the cache mutex is poisoned, the operation is silently skipped.

Source

pub fn hits(&self) -> u64

Returns the number of cache hits.

§Returns

The total number of successful cache lookups.

Source

pub fn misses(&self) -> u64

Returns the number of cache misses.

§Returns

The total number of unsuccessful cache lookups.

Source

pub fn hit_rate(&self) -> f64

Returns the cache hit rate as a percentage.

§Returns

The hit rate as a float between 0.0 and 100.0. Returns 0.0 if no cache operations have occurred.

Source

pub fn size(&self) -> usize

Returns the current number of items in the cache.

§Returns

The number of items currently stored in the cache. Returns 0 if the cache mutex is poisoned.

Source

pub fn capacity(&self) -> usize

Returns the maximum capacity of the cache.

§Returns

The maximum number of items the cache can hold.

Source

pub fn evictions(&self) -> u64

Returns the number of cache evictions.

§Returns

The total number of items evicted from the cache.

Auto Trait Implementations§

§

impl !Freeze for Cache

§

impl RefUnwindSafe for Cache

§

impl Send for Cache

§

impl Sync for Cache

§

impl Unpin for Cache

§

impl UnwindSafe for Cache

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> 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> Same for T

Source§

type Output = T

Should always be Self
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.
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