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

#269 in Memory management

Download history 47/week @ 2023-12-11 15/week @ 2023-12-18 13/week @ 2023-12-25 15/week @ 2024-01-01 107/week @ 2024-01-08 15/week @ 2024-01-15 8/week @ 2024-01-22 45/week @ 2024-01-29 73/week @ 2024-02-05 46/week @ 2024-02-12 79/week @ 2024-02-19 19/week @ 2024-02-26 31/week @ 2024-03-04 17/week @ 2024-03-11 32/week @ 2024-03-18 13/week @ 2024-03-25

94 downloads per month
Used in 2 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

~49KB