Cache

Struct Cache 

Source
pub struct Cache<K, V>
where K: Hash + Eq + Clone,
{ /* private fields */ }
Expand description

Provides a reliable cache for HashMap<Key, Value> where value can be derived from key, but could be expensive to generate. The cache is thread safe and can be used in multi-threaded environment. The cache is not async, so it is not suitable for async environment. For async cache, use CasheAsync instead.

use anycache::Cache;
use anycache::CacheAsync;
 
fn my_gen(x:&String) -> String {
  println!("Generating {}", x);
  let mut y = x.clone();
  y.push_str("@");
  y
}
 
// For async cache, use CacheAsync
fn test_sync_cache() {
  let c = Cache::new(my_gen);
 
  for j in 0..2 {
    for i in 0..10 {
      let key = format!("key{}", i);
      let v = c.get(&key);
      println!("{}:{}: {}", j, i, *v);
    }
  }
}
 
// For sync cache, use Cache
async fn test_cache_async() {
  // Cache is only generated once above. Similarly, for Async.
 
  let c = CacheAsync::new(my_gen);
 
  for j in 0..2 {
    for i in 0..10 {
      let key = format!("key{}", i);
      let v = c.get(&key).await;
      println!("{}:{}: {}", j, i, *v);
    }
  }
}
 

Create a Cache with K, V type. Similar to Map. However, the value is generated from key on-demand using generate function

Implementations§

Source§

impl<K, V> Cache<K, V>
where K: Hash + Eq + Clone,

Source

pub fn new(generator: impl Fn(&K) -> V + 'static + Sync) -> Self
where K: Hash + Eq,

Create a new cache using the given generator function

Source

pub fn get_if(&self, key: &K) -> Option<Arc<V>>

Get from the cache. If the key is missing, do not generate it and return None

Source

pub fn drop(&self, key: &K)

Drop the key from the cache if it exists Does nothing if the key is not there

Source

pub fn get(&self, key: &K) -> Arc<V>

Get the key from cache. If not found, generate one.

Auto Trait Implementations§

§

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

§

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

§

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

§

impl<K, V> Sync for Cache<K, V>
where K: Send + Sync, V: Sync + Send,

§

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

§

impl<K, V> !UnwindSafe for Cache<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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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