#key-value #cache #pair #lru-cache #numbers #limited #hold

xlru-cache

A cache that holds a limited number of key-value pairs

1 unstable release

Uses old Rust 2015

0.1.2 Nov 24, 2019

#19 in #hold

Download history 123/week @ 2024-08-31 96/week @ 2024-09-07 307/week @ 2024-09-14 41/week @ 2024-09-21 96/week @ 2024-09-28 134/week @ 2024-10-05 75/week @ 2024-10-12 24/week @ 2024-10-19 7/week @ 2024-10-26 49/week @ 2024-11-02 75/week @ 2024-11-09 64/week @ 2024-11-16 76/week @ 2024-11-23 61/week @ 2024-11-30 20/week @ 2024-12-07 25/week @ 2024-12-14

198 downloads per month
Used in arc-cache

MIT/Apache

20KB
284 lines

WARNING: THIS PROJECT IS IN MAINTENANCE MODE, DUE TO INSUFFICIENT MAINTAINER RESOURCES

It works fine, but will generally no longer be improved.

We are currently only accepting changes which:

  • keep this compiling with the latest versions of Rust or its dependencies.
  • have minimal review requirements, such as documentation changes (so not totally new APIs).

A cache that holds a limited number of key-value pairs.

Documentation is available at https://contain-rs.github.io/lru-cache/lru_cache.


lib.rs:

A cache that holds a limited number of key-value pairs. When the capacity of the cache is exceeded, the least-recently-used (where "used" means a look-up or putting the pair into the cache) pair is automatically removed.

Examples

use lru_cache::LruCache;

let mut cache = LruCache::new(2);

cache.insert(1, 10);
cache.insert(2, 20);
cache.insert(3, 30);
assert!(cache.get_mut(&1).is_none());
assert_eq!(*cache.get_mut(&2).unwrap(), 20);
assert_eq!(*cache.get_mut(&3).unwrap(), 30);

cache.insert(2, 22);
assert_eq!(*cache.get_mut(&2).unwrap(), 22);

cache.insert(6, 60);
assert!(cache.get_mut(&3).is_none());

cache.set_capacity(1);
assert!(cache.get_mut(&2).is_none());

Dependencies

~220KB