pub struct VacantEntry<'a, T, A = Global>where
A: Allocator,{
tag: Tag,
index: usize,
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 hashbrown::hash_table::{Entry, VacantEntry};
use hashbrown::{HashTable, DefaultHashBuilder};
use std::hash::BuildHasher;
let mut table: HashTable<&str> = HashTable::new();
let hasher = DefaultHashBuilder::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§
§tag: Tag§index: usize§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 hashbrown::hash_table::Entry;
use hashbrown::{HashTable, DefaultHashBuilder};
use std::hash::BuildHasher;
let mut table: HashTable<&str> = HashTable::new();
let hasher = DefaultHashBuilder::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 = Global> !DynSend for VacantEntry<'a, T, A>
impl<'a, T, A = Global> !DynSync for VacantEntry<'a, T, A>
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
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 24 bytes