CacheMap is a data structure for concurrently caching values.
The cache
function will look up a value in the map, or generate and store a new one using the
provided function.
This is a updated and maintained fork of hclarke/cachemap.
``` use cachemap::CacheMap;
let m = CacheMap::new();
let fst = m.cache("key", || 5u32); let snd = m.cache("key", || 7u32);
asserteq!(*fst, *snd); asserteq!(*fst, 5u32); ```
&CacheMap<K,V>
rather than &mut CacheMap<K,V>
).dashmap
feature, which uses dashmap
internally and allows:
Arc<V>
pointers, in case values need to outlive the map, andArc<V>
directly, allowing unsized values, and re-using Arc<V>
s from elsewhere.abi_stable
feature which will derive abi_stable::StableAbi
on the type.