pub struct DashSet<K, S = RandomState> { /* private fields */ }
Expand description
DashSet is a thin wrapper around DashMap
using ()
as the value type. It uses
methods and types which are more convenient to work with on a set.
Implementations§
Source§impl<'a, K: 'a + Eq + Hash> DashSet<K, RandomState>
impl<'a, K: 'a + Eq + Hash> DashSet<K, RandomState>
Sourcepub fn new() -> Self
pub fn new() -> Self
Creates a new DashSet with a capacity of 0.
§Examples
use dashmap::DashSet;
let games = DashSet::new();
games.insert("Veloren");
Sourcepub fn with_capacity(capacity: usize) -> Self
pub fn with_capacity(capacity: usize) -> Self
Creates a new DashMap with a specified starting capacity.
§Examples
use dashmap::DashSet;
let numbers = DashSet::with_capacity(2);
numbers.insert(2);
numbers.insert(8);
Source§impl<'a, K: 'a + Eq + Hash, S: BuildHasher + Clone> DashSet<K, S>
impl<'a, K: 'a + Eq + Hash, S: BuildHasher + Clone> DashSet<K, S>
Sourcepub fn with_hasher(hasher: S) -> Self
pub fn with_hasher(hasher: S) -> Self
Creates a new DashMap with a capacity of 0 and the provided hasher.
§Examples
use dashmap::DashSet;
use std::collections::hash_map::RandomState;
let s = RandomState::new();
let games = DashSet::with_hasher(s);
games.insert("Veloren");
Sourcepub fn with_capacity_and_hasher(capacity: usize, hasher: S) -> Self
pub fn with_capacity_and_hasher(capacity: usize, hasher: S) -> Self
Creates a new DashMap with a specified starting capacity and hasher.
§Examples
use dashmap::DashSet;
use std::collections::hash_map::RandomState;
let s = RandomState::new();
let numbers = DashSet::with_capacity_and_hasher(2, s);
numbers.insert(2);
numbers.insert(8);
Sourcepub fn hash_usize<T: Hash>(&self, item: &T) -> usize
pub fn hash_usize<T: Hash>(&self, item: &T) -> usize
Hash a given item to produce a usize. Uses the provided or default HashBuilder.
Sourcepub fn insert(&self, key: K) -> bool
pub fn insert(&self, key: K) -> bool
Inserts a key into the set. Returns true if the key was not already in the set.
§Examples
use dashmap::DashSet;
let set = DashSet::new();
set.insert("I am the key!");
Sourcepub fn remove<Q>(&self, key: &Q) -> Option<K>
pub fn remove<Q>(&self, key: &Q) -> Option<K>
Removes an entry from the map, returning the key if it existed in the map.
§Examples
use dashmap::DashSet;
let soccer_team = DashSet::new();
soccer_team.insert("Jack");
assert_eq!(soccer_team.remove("Jack").unwrap(), "Jack");
Sourcepub fn remove_if<Q>(&self, key: &Q, f: impl FnOnce(&K) -> bool) -> Option<K>
pub fn remove_if<Q>(&self, key: &Q, f: impl FnOnce(&K) -> bool) -> Option<K>
Removes an entry from the set, returning the key if the entry existed and the provided conditional function returned true.
use dashmap::DashSet;
let soccer_team = DashSet::new();
soccer_team.insert("Sam");
soccer_team.remove_if("Sam", |player| player.starts_with("Ja"));
assert!(soccer_team.contains("Sam"));
use dashmap::DashSet;
let soccer_team = DashSet::new();
soccer_team.insert("Sam");
soccer_team.remove_if("Jacob", |player| player.starts_with("Ja"));
assert!(!soccer_team.contains("Jacob"));
Sourcepub fn iter(&'a self) -> Iter<'a, K, S, DashMap<K, (), S>> ⓘ
pub fn iter(&'a self) -> Iter<'a, K, S, DashMap<K, (), S>> ⓘ
Creates an iterator over a DashMap yielding immutable references.
§Examples
use dashmap::DashSet;
let words = DashSet::new();
words.insert("hello");
assert_eq!(words.iter().count(), 1);
Sourcepub fn get<Q>(&'a self, key: &Q) -> Option<Ref<'a, K>>
pub fn get<Q>(&'a self, key: &Q) -> Option<Ref<'a, K>>
Get a reference to an entry in the set
§Examples
use dashmap::DashSet;
let youtubers = DashSet::new();
youtubers.insert("Bosnian Bill");
assert_eq!(*youtubers.get("Bosnian Bill").unwrap(), "Bosnian Bill");
Sourcepub fn shrink_to_fit(&self)
pub fn shrink_to_fit(&self)
Remove excess capacity to reduce memory usage.
Sourcepub fn retain(&self, f: impl FnMut(&K) -> bool)
pub fn retain(&self, f: impl FnMut(&K) -> bool)
Retain elements that whose predicates return true and discard elements whose predicates return false.
§Examples
use dashmap::DashSet;
let people = DashSet::new();
people.insert("Albin");
people.insert("Jones");
people.insert("Charlie");
people.retain(|name| name.contains('i'));
assert_eq!(people.len(), 2);
Sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Fetches the total number of keys stored in the set.
§Examples
use dashmap::DashSet;
let people = DashSet::new();
people.insert("Albin");
people.insert("Jones");
people.insert("Charlie");
assert_eq!(people.len(), 3);
Sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Checks if the set is empty or not.
§Examples
use dashmap::DashSet;
let map = DashSet::<()>::new();
assert!(map.is_empty());
Trait Implementations§
Source§impl<K: Eq + Hash, S: BuildHasher + Clone> Extend<K> for DashSet<K, S>
impl<K: Eq + Hash, S: BuildHasher + Clone> Extend<K> for DashSet<K, S>
Source§fn extend<T: IntoIterator<Item = K>>(&mut self, iter: T)
fn extend<T: IntoIterator<Item = K>>(&mut self, iter: T)
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one
)Source§impl<K: Eq + Hash, S: BuildHasher + Clone + Default> FromIterator<K> for DashSet<K, S>
impl<K: Eq + Hash, S: BuildHasher + Clone + Default> FromIterator<K> for DashSet<K, S>
Source§fn from_iter<I: IntoIterator<Item = K>>(iter: I) -> Self
fn from_iter<I: IntoIterator<Item = K>>(iter: I) -> Self
Source§impl<K, S> FromParallelIterator<K> for DashSet<K, S>
impl<K, S> FromParallelIterator<K> for DashSet<K, S>
Source§fn from_par_iter<I>(par_iter: I) -> Selfwhere
I: IntoParallelIterator<Item = K>,
fn from_par_iter<I>(par_iter: I) -> Selfwhere
I: IntoParallelIterator<Item = K>,
par_iter
. Read moreSource§impl<K: Eq + Hash, S: BuildHasher + Clone> IntoIterator for DashSet<K, S>
impl<K: Eq + Hash, S: BuildHasher + Clone> IntoIterator for DashSet<K, S>
Source§impl<'a, K, S> IntoParallelIterator for &'a DashSet<K, S>
impl<'a, K, S> IntoParallelIterator for &'a DashSet<K, S>
Source§impl<K, S> IntoParallelIterator for DashSet<K, S>
impl<K, S> IntoParallelIterator for DashSet<K, S>
Source§impl<K, S> ParallelExtend<K> for &DashSet<K, S>
impl<K, S> ParallelExtend<K> for &DashSet<K, S>
Source§fn par_extend<I>(&mut self, par_iter: I)where
I: IntoParallelIterator<Item = K>,
fn par_extend<I>(&mut self, par_iter: I)where
I: IntoParallelIterator<Item = K>,
par_iter
. Read moreSource§impl<K, S> ParallelExtend<K> for DashSet<K, S>
impl<K, S> ParallelExtend<K> for DashSet<K, S>
Source§fn par_extend<I>(&mut self, par_iter: I)where
I: IntoParallelIterator<Item = K>,
fn par_extend<I>(&mut self, par_iter: I)where
I: IntoParallelIterator<Item = K>,
par_iter
. Read moreAuto Trait Implementations§
impl<K, S> Freeze for DashSet<K, S>where
S: Freeze,
impl<K, S = RandomState> !RefUnwindSafe for DashSet<K, S>
impl<K, S> Send for DashSet<K, S>
impl<K, S> Sync for DashSet<K, S>
impl<K, S> Unpin for DashSet<K, S>where
S: Unpin,
impl<K, S> UnwindSafe for DashSet<K, S>where
S: UnwindSafe,
K: UnwindSafe,
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)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>
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>
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 more