pub struct CacheBuilder<K, V, C> { /* private fields */ }
Expand description
Builds a Cache
with various configuration knobs.
§Examples
use moka::unsync::Cache;
use std::time::Duration;
let mut cache = Cache::builder()
// Max 10,000 elements
.max_capacity(10_000)
// Time to live (TTL): 30 minutes
.time_to_live(Duration::from_secs(30 * 60))
// Time to idle (TTI): 5 minutes
.time_to_idle(Duration::from_secs( 5 * 60))
// Create the cache.
.build();
// This entry will expire after 5 minutes (TTI) if there is no get().
cache.insert(0, "zero");
// This get() will extend the entry life for another 5 minutes.
cache.get(&0);
// Even though we keep calling get(), the entry will expire
// after 30 minutes (TTL) from the insert().
Implementations§
Source§impl<K, V> CacheBuilder<K, V, Cache<K, V, RandomState>>
impl<K, V> CacheBuilder<K, V, Cache<K, V, RandomState>>
Sourcepub fn new(max_capacity: u64) -> Self
pub fn new(max_capacity: u64) -> Self
Construct a new CacheBuilder
that will be used to build a Cache
holding
up to max_capacity
entries.
Sourcepub fn build(self) -> Cache<K, V, RandomState>
pub fn build(self) -> Cache<K, V, RandomState>
Builds a Cache<K, V>
.
§Panics
Panics if configured with either time_to_live
or time_to_idle
higher than
1000 years. This is done to protect against overflow when computing key
expiration.
Sourcepub fn build_with_hasher<S>(self, hasher: S) -> Cache<K, V, S>where
S: BuildHasher + Clone,
pub fn build_with_hasher<S>(self, hasher: S) -> Cache<K, V, S>where
S: BuildHasher + Clone,
Builds a Cache<K, V, S>
, with the given hasher
.
§Panics
Panics if configured with either time_to_live
or time_to_idle
higher than
1000 years. This is done to protect against overflow when computing key
expiration.
Source§impl<K, V, C> CacheBuilder<K, V, C>
impl<K, V, C> CacheBuilder<K, V, C>
Sourcepub fn max_capacity(self, max_capacity: u64) -> Self
pub fn max_capacity(self, max_capacity: u64) -> Self
Sets the max capacity of the cache.
Sourcepub fn initial_capacity(self, number_of_entries: usize) -> Self
pub fn initial_capacity(self, number_of_entries: usize) -> Self
Sets the initial capacity (number of entries) of the cache.
Sourcepub fn weigher(self, weigher: impl FnMut(&K, &V) -> u32 + 'static) -> Self
pub fn weigher(self, weigher: impl FnMut(&K, &V) -> u32 + 'static) -> Self
Sets the weigher closure of the cache.
The closure should take &K
and &V
as the arguments and returns a u32
representing the relative size of the entry.
Sourcepub fn time_to_live(self, duration: Duration) -> Self
pub fn time_to_live(self, duration: Duration) -> Self
Sets the time to live of the cache.
A cached entry will be expired after the specified duration past from
insert
.
§Panics
CacheBuilder::build*
methods will panic if the given duration
is longer
than 1000 years. This is done to protect against overflow when computing key
expiration.
Sourcepub fn time_to_idle(self, duration: Duration) -> Self
pub fn time_to_idle(self, duration: Duration) -> Self
Sets the time to idle of the cache.
A cached entry will be expired after the specified duration past from get
or insert
.
§Panics
CacheBuilder::build*
methods will panic if the given duration
is longer
than 1000 years. This is done to protect against overflow when computing key
expiration.