pub struct GdsfCache<K, V, S = DefaultHashBuilder> { /* private fields */ }Expand description
An implementation of a Greedy Dual-Size Frequency (GDSF) cache.
Implementations§
Source§impl<K: Hash + Eq, V: Clone, S: BuildHasher> GdsfCache<K, V, S>
impl<K: Hash + Eq, V: Clone, S: BuildHasher> GdsfCache<K, V, S>
pub fn with_hasher(cap: NonZeroUsize, hash_builder: S) -> Self
pub fn cap(&self) -> NonZeroUsize
pub fn len(&self) -> usize
pub fn is_empty(&self) -> bool
pub fn global_age(&self) -> f64
pub fn record_miss(&mut self, object_size: u64)
pub fn get<Q>(&mut self, key: &Q) -> Option<V>
pub fn get_mut<Q>(&mut self, key: &Q) -> Option<&mut V>
pub fn contains_key<Q>(&self, key: &Q) -> bool
pub fn put(&mut self, key: K, val: V, size: u64) -> Option<V>where
K: Clone,
pub fn pop<Q>(&mut self, key: &Q) -> Option<V>
pub fn clear(&mut self)
Source§impl<K: Hash + Eq, V: Clone> GdsfCache<K, V, DefaultHashBuilder>
impl<K: Hash + Eq, V: Clone> GdsfCache<K, V, DefaultHashBuilder>
pub fn new(cap: NonZeroUsize) -> Self
Trait Implementations§
Source§impl<K: Hash + Eq, V: Clone, S: BuildHasher> CacheMetrics for GdsfCache<K, V, S>
impl<K: Hash + Eq, V: Clone, S: BuildHasher> CacheMetrics for GdsfCache<K, V, S>
Auto Trait Implementations§
impl<K, V, S> Freeze for GdsfCache<K, V, S>where
S: Freeze,
impl<K, V, S> RefUnwindSafe for GdsfCache<K, V, S>
impl<K, V, S> Send for GdsfCache<K, V, S>
impl<K, V, S> Sync for GdsfCache<K, V, S>
impl<K, V, S> Unpin for GdsfCache<K, V, S>
impl<K, V, S> UnwindSafe for GdsfCache<K, V, S>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more