4 releases

0.2.0 Feb 5, 2020
0.1.2 Jan 31, 2020
0.1.1 Jan 29, 2020
0.1.0 Jan 28, 2020

#256 in Memory management

Download history 20/week @ 2024-02-25 28/week @ 2024-03-03 21/week @ 2024-03-10 31/week @ 2024-03-17 1/week @ 2024-03-24 27/week @ 2024-03-31 16/week @ 2024-04-07 12/week @ 2024-04-14 29/week @ 2024-04-21 73/week @ 2024-04-28 33/week @ 2024-05-05 15/week @ 2024-05-12 40/week @ 2024-05-19 12/week @ 2024-05-26 108/week @ 2024-06-02 45/week @ 2024-06-09

206 downloads per month
Used in 3 crates

MIT license

18KB
203 lines

memory-cache-rs

Simple local in-memory cache for Rust.

  1. Example
  2. Memoization
  3. Breaking Changes
  4. Licence

Example

use std::time::Duration;
use memory_cache::MemoryCache;

let mut cache = MemoryCache::new();

let key: &'static str = "key";
let value: &'static str = "Hello, World!";

// `None` - if the value must be kept forever.
let lifetime = Some(Duration::from_secs(30));

cache.insert(key, value, lifetime);

assert_eq!(cache.get(&key), Some(&value));

Memoization

use once_cell::sync::Lazy;
use std::sync::Mutex;
use memory_cache::{MemoryCache, cached};

cached! {
    fn factorial(x: u128) -> u128 = {
        if x <= 1 {
            1
        } else {
            x * factorial(x - 1)
        }
    }
}

assert_eq!(factorial(21), 51090942171709440000);

Breaking Changes:

0.2.0:

Constructors:

- MemoryCache::new(full_scan_frequency: Duration) -> Self
+ MemoryCache::new() -> Self
+ MemoryCache::with_full_scan(full_scan_frequency: Duration) -> Self

Renamed Methods:

To look like a HashMap.

MemoryCache<A, B> {

-   fn has_key(&self, key: &A) -> bool
+   fn contains_key(&self, key: &A) -> bool

-   fn set(&mut self, key: A, value: B, duration: Option<Duration>) -> Option<B>
+   fn insert(&mut self, key: A, value: B, lifetime: Option<Duration>) -> Option<B>

-   fn get_or_set<F>(&mut self, key: A, factory: F, duration: Option<Duration>) -> &B
+   fn get_or_insert<F>(&mut self, key: A, factory: F, lifetime: Option<Duration>) -> &B

}

Changed types of parameters/results:

MemoryCache<A, B> {

-   fn get_full_scan_frequency(&self) -> &Duration
+   fn get_full_scan_frequency(&self) -> Option<Duration>

}

Licence

MIT

Dependencies

~48KB