Enum foyer_memory::Cache

source ·
pub enum Cache<K, V, S = RandomState>
where K: Key, V: Value, S: HashBuilder,
{ Fifo(Arc<GenericCache<K, V, SanityEviction<Fifo<(K, V)>>, SanityIndexer<HashTableIndexer<K, FifoHandle<(K, V)>>>, S>>), Lru(Arc<GenericCache<K, V, SanityEviction<Lru<(K, V)>>, SanityIndexer<HashTableIndexer<K, LruHandle<(K, V)>>>, S>>), Lfu(Arc<GenericCache<K, V, SanityEviction<Lfu<(K, V)>>, SanityIndexer<HashTableIndexer<K, LfuHandle<(K, V)>>>, S>>), S3Fifo(Arc<GenericCache<K, V, SanityEviction<S3Fifo<(K, V)>>, SanityIndexer<HashTableIndexer<K, S3FifoHandle<(K, V)>>>, S>>), }
Expand description

In-memory cache with plug-and-play algorithms.

Variants§

§

Fifo(Arc<GenericCache<K, V, SanityEviction<Fifo<(K, V)>>, SanityIndexer<HashTableIndexer<K, FifoHandle<(K, V)>>>, S>>)

In-memory FIFO cache.

§

Lru(Arc<GenericCache<K, V, SanityEviction<Lru<(K, V)>>, SanityIndexer<HashTableIndexer<K, LruHandle<(K, V)>>>, S>>)

In-memory LRU cache.

§

Lfu(Arc<GenericCache<K, V, SanityEviction<Lfu<(K, V)>>, SanityIndexer<HashTableIndexer<K, LfuHandle<(K, V)>>>, S>>)

In-memory LFU cache.

§

S3Fifo(Arc<GenericCache<K, V, SanityEviction<S3Fifo<(K, V)>>, SanityIndexer<HashTableIndexer<K, S3FifoHandle<(K, V)>>>, S>>)

In-memory S3FIFO cache.

Implementations§

source§

impl<K, V, S> Cache<K, V, S>
where K: Key, V: Value, S: HashBuilder,

source

pub fn insert(&self, key: K, value: V) -> CacheEntry<K, V, S>

Insert cache entry to the in-memory cache.

source

pub fn insert_with_context( &self, key: K, value: V, context: CacheContext, ) -> CacheEntry<K, V, S>

Insert cache entry with cache context to the in-memory cache.

source

pub fn deposit(&self, key: K, value: V) -> CacheEntry<K, V, S>

Temporarily insert cache entry to the in-memory cache.

The entry will be removed as soon as the returned entry is dropped.

The entry will become a normal entry after it is accessed.

source

pub fn deposit_with_context( &self, key: K, value: V, context: CacheContext, ) -> CacheEntry<K, V, S>

Temporarily insert cache entry with cache context to the in-memory cache.

The entry will be removed as soon as the returned entry is dropped.

The entry will become a normal entry after it is accessed.

source

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

Remove a cached entry with the given key from the in-memory cache.

source

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

Get cached entry with the given key from the in-memory cache.

source

pub fn contains<Q>(&self, key: &Q) -> bool
where K: Borrow<Q>, Q: Hash + Eq + ?Sized,

Check if the in-memory cache contains a cached entry with the given key.

source

pub fn touch<Q>(&self, key: &Q) -> bool
where K: Borrow<Q>, Q: Hash + Eq + ?Sized,

Access the cached entry with the given key but don’t return.

Note: This method can be used to update the cache eviction information and order based on the algorithm.

source

pub fn clear(&self)

Clear the in-memory cache.

source

pub fn capacity(&self) -> usize

Get the capacity of the in-memory cache.

source

pub fn usage(&self) -> usize

Get the usage of the in-memory cache.

source

pub fn hash_builder(&self) -> &S

Get the hash builder of the in-memory cache.

source§

impl<K, V, S> Cache<K, V, S>
where K: Key + Clone, V: Value, S: HashBuilder,

source

pub fn fetch<F, FU, ER>(&self, key: K, fetch: F) -> Fetch<K, V, ER, S>
where F: FnOnce() -> FU, FU: Future<Output = Result<(V, CacheContext), ER>> + Send + 'static, ER: Send + 'static + Debug,

Get the cached entry with the given key from the in-memory cache.

Use fetch to fetch the cache value from the remote storage on cache miss.

The concurrent fetch requests will be deduplicated.

source

pub fn fetch_with_runtime<F, FU, ER>( &self, key: K, fetch: F, runtime: &Handle, ) -> Fetch<K, V, ER, S>
where F: FnOnce() -> FU, FU: Future<Output = Result<(V, CacheContext), ER>> + Send + 'static, ER: Send + 'static + Debug,

Get the cached entry with the given key from the in-memory cache.

The fetch task will be spawned in the give runtime.

Use fetch to fetch the cache value from the remote storage on cache miss.

The concurrent fetch requests will be deduplicated.

Trait Implementations§

source§

impl<K, V, S> Clone for Cache<K, V, S>
where K: Key, V: Value, S: HashBuilder,

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<K, V, S> Debug for Cache<K, V, S>
where K: Key, V: Value, S: HashBuilder,

source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<K, V, S> Freeze for Cache<K, V, S>

§

impl<K, V, S = RandomState> !RefUnwindSafe for Cache<K, V, S>

§

impl<K, V, S> Send for Cache<K, V, S>

§

impl<K, V, S> Sync for Cache<K, V, S>

§

impl<K, V, S> Unpin for Cache<K, V, S>

§

impl<K, V, S = RandomState> !UnwindSafe for Cache<K, V, S>

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

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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<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.
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
source§

impl<T> Value for T
where T: Send + Sync + 'static,