Struct hashbrown::table::VacantEntry
source · pub struct VacantEntry<'a, T, A = Global>where
A: Allocator,{
hash: u64,
insert_slot: InsertSlot,
table: &'a mut HashTable<T, A>,
}
Expand description
A view into a vacant entry in a HashTable
.
It is part of the Entry
enum.
§Examples
use ahash::AHasher;
use hashbrown::hash_table::{Entry, HashTable, VacantEntry};
use std::hash::{BuildHasher, BuildHasherDefault};
let mut table: HashTable<&str> = HashTable::new();
let hasher = BuildHasherDefault::<AHasher>::default();
let hasher = |val: &_| hasher.hash_one(val);
let entry_v: VacantEntry<_, _> = match table.entry(hasher(&"a"), |&x| x == "a", hasher) {
Entry::Vacant(view) => view,
Entry::Occupied(_) => unreachable!(),
};
entry_v.insert("a");
assert!(table.find(hasher(&"a"), |&x| x == "a").is_some() && table.len() == 1);
// Nonexistent key (insert)
match table.entry(hasher(&"b"), |&x| x == "b", hasher) {
Entry::Vacant(view) => {
view.insert("b");
}
Entry::Occupied(_) => unreachable!(),
}
assert!(table.find(hasher(&"b"), |&x| x == "b").is_some() && table.len() == 2);
Fields§
§hash: u64
§insert_slot: InsertSlot
§table: &'a mut HashTable<T, A>
Implementations§
source§impl<'a, T, A> VacantEntry<'a, T, A>where
A: Allocator,
impl<'a, T, A> VacantEntry<'a, T, A>where
A: Allocator,
sourcepub fn insert(self, value: T) -> OccupiedEntry<'a, T, A>
pub fn insert(self, value: T) -> OccupiedEntry<'a, T, A>
Inserts a new element into the table with the hash that was used to
obtain the VacantEntry
.
An OccupiedEntry
is returned for the newly inserted element.
§Examples
use ahash::AHasher;
use hashbrown::hash_table::Entry;
use hashbrown::HashTable;
use std::hash::{BuildHasher, BuildHasherDefault};
let mut table: HashTable<&str> = HashTable::new();
let hasher = BuildHasherDefault::<AHasher>::default();
let hasher = |val: &_| hasher.hash_one(val);
if let Entry::Vacant(o) = table.entry(hasher(&"poneyland"), |&x| x == "poneyland", hasher) {
o.insert("poneyland");
}
assert_eq!(
table.find(hasher(&"poneyland"), |&x| x == "poneyland"),
Some(&"poneyland")
);
sourcepub fn into_table(self) -> &'a mut HashTable<T, A>
pub fn into_table(self) -> &'a mut HashTable<T, A>
Converts the VacantEntry into a mutable reference to the underlying table.
Trait Implementations§
Auto Trait Implementations§
impl<'a, T, A> Freeze for VacantEntry<'a, T, A>
impl<'a, T, A> RefUnwindSafe for VacantEntry<'a, T, A>where
A: RefUnwindSafe,
T: RefUnwindSafe,
impl<'a, T, A> Send for VacantEntry<'a, T, A>
impl<'a, T, A> Sync for VacantEntry<'a, T, A>
impl<'a, T, A> Unpin for VacantEntry<'a, T, A>
impl<'a, T, A = Global> !UnwindSafe for VacantEntry<'a, T, A>
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