pub enum Entry<'a, K, V, S> where
K: Hash + Eq + Clone,
V: Clone,
S: BuildHasher, {
Occupied(OccupiedEntry<'a, K, V, S>),
Vacant(VacantEntry<'a, K, V, S>),
}
Expand description
A handle for a key and its associated value.
Performance Note
When using an Entry
, the key is only ever hashed once, when you
create the Entry
. Operations on an Entry
will never trigger a
rehash, where eg. a contains_key(key)
followed by an
insert(key, default_value)
(the equivalent of
Entry::or_insert()
) would need to hash the key once for the
contains_key
and again for the insert
. The operations
generally perform similarly otherwise.
Variants
Occupied(OccupiedEntry<'a, K, V, S>)
An entry which exists in the map.
Vacant(VacantEntry<'a, K, V, S>)
An entry which doesn’t exist in the map.
Implementations
sourceimpl<'a, K, V, S> Entry<'a, K, V, S> where
K: 'a + Hash + Eq + Clone,
V: 'a + Clone,
S: 'a + BuildHasher,
impl<'a, K, V, S> Entry<'a, K, V, S> where
K: 'a + Hash + Eq + Clone,
V: 'a + Clone,
S: 'a + BuildHasher,
sourcepub fn or_insert(self, default: V) -> &'a mut V
pub fn or_insert(self, default: V) -> &'a mut V
Insert the default value provided if there was no value already, and return a mutable reference to the value.
sourcepub fn or_insert_with<F>(self, default: F) -> &'a mut V where
F: FnOnce() -> V,
pub fn or_insert_with<F>(self, default: F) -> &'a mut V where
F: FnOnce() -> V,
Insert the default value from the provided function if there was no value already, and return a mutable reference to the value.
sourcepub fn or_default(self) -> &'a mut V where
V: Default,
pub fn or_default(self) -> &'a mut V where
V: Default,
Insert a default value if there was no value already, and return a mutable reference to the value.
sourcepub fn and_modify<F>(self, f: F) -> Self where
F: FnOnce(&mut V),
pub fn and_modify<F>(self, f: F) -> Self where
F: FnOnce(&mut V),
Call the provided function to modify the value if the value exists.
Auto Trait Implementations
impl<'a, K, V, S> RefUnwindSafe for Entry<'a, K, V, S> where
K: RefUnwindSafe,
S: RefUnwindSafe,
V: RefUnwindSafe,
impl<'a, K, V, S> !Send for Entry<'a, K, V, S>
impl<'a, K, V, S> !Sync for Entry<'a, K, V, S>
impl<'a, K, V, S> Unpin for Entry<'a, K, V, S> where
K: Unpin,
impl<'a, K, V, S> !UnwindSafe for Entry<'a, K, V, S>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more