Crates.io | weight-lru |
lib.rs | weight-lru |
version | 0.0.3 |
created_at | 2025-02-12 06:37:03.658671+00 |
updated_at | 2025-03-06 10:02:02.187015+00 |
description | A LRU cache implementation |
homepage | https://github.com/cloverstd/weight-lru-rs |
repository | https://github.com/cloverstd/weight-lru-rs.git |
max_upload_size | |
id | 1552636 |
size | 123,157 |
This repository forked from LRU Cache.
An implementation of a LRU cache. The cache supports put
, get
, get_mut
and pop
operations,
all of which are O(1). This crate was heavily influenced by the LRU Cache implementation in an
earlier version of Rust's std::collections crate.
The MSRV for this crate is 1.65.0.
Below is a simple example of how to instantiate and use a LRU cache.
extern crate weight_lru;
use weight_lru::LruCache;
use std::num::NonZeroUsize;
fn main() {
let mut cache = LruCache::new(NonZeroUsize::new(2).unwrap());
cache.put("apple", 3, NoneZeroUsize::new(1).unwrap());
cache.put("banana", 2, NoneZeroUsize::new(1).unwrap());
assert_eq!(*cache.get(&"apple").unwrap(), 3);
assert_eq!(*cache.get(&"banana").unwrap(), 2);
assert!(cache.get(&"pear").is_none());
assert_eq!(cache.put("banana", 4, NoneZeroUsize::new(1).unwrap()), Some(2));
assert_eq!(cache.put("pear", 5, NoneZeroUsize::new(1).unwrap()), None);
assert_eq!(*cache.get(&"pear").unwrap(), 5);
assert_eq!(*cache.get(&"banana").unwrap(), 4);
assert!(cache.get(&"apple").is_none());
{
let v = cache.get_mut(&"banana").unwrap();
*v = 6;
}
assert_eq!(*cache.get(&"banana").unwrap(), 6);
}