pub struct Set<K: Ord + Clone, const SIZE: usize>(/* private fields */);
Expand description
This set uses a similar strategy to BTreeSet to ensure cache efficient performance on modern hardware while still providing log(N) get, insert, and remove operations.
§Examples
use alloc::string::String;
use self::immutable_chunkmap::set::SetM;
let m =
SetM::new()
.insert(String::from("1")).0
.insert(String::from("2")).0
.insert(String::from("3")).0;
assert_eq!(m.contains("1"), true);
assert_eq!(m.contains("2"), true);
assert_eq!(m.contains("3"), true);
assert_eq!(m.contains("4"), false);
for k in &m { println!("{}", k) }
Implementations§
source§impl<K, const SIZE: usize> Set<K, SIZE>
impl<K, const SIZE: usize> Set<K, SIZE>
sourcepub fn downgrade(&self) -> WeakSetRef<K, SIZE>
pub fn downgrade(&self) -> WeakSetRef<K, SIZE>
Create a weak reference to this set
sourcepub fn strong_count(&self) -> usize
pub fn strong_count(&self) -> usize
Return the number of strong references to this set (see Arc)
sourcepub fn weak_count(&self) -> usize
pub fn weak_count(&self) -> usize
Return the number of weak references to this set (see Arc)
sourcepub fn insert_many<E: IntoIterator<Item = K>>(&self, elts: E) -> Self
pub fn insert_many<E: IntoIterator<Item = K>>(&self, elts: E) -> Self
This will insert many elements at once, and is potentially a lot faster than inserting one by one, especially if the data is sorted.
#Examples
use self::immutable_chunkmap::set::SetM;
let mut v = vec![1, 10, -12, 44, 50];
v.sort_unstable();
let m = SetM::new().insert_many(v.iter().map(|k| *k));
for k in &v {
assert_eq!(m.contains(k), true)
}
sourcepub fn remove_many<Q, E>(&self, elts: E) -> Self
pub fn remove_many<Q, E>(&self, elts: E) -> Self
Remove multiple elements in a single pass. Similar performance to insert_many.
sourcepub fn update_many<Q, E, F>(&self, elts: E, f: F) -> Self
pub fn update_many<Q, E, F>(&self, elts: E, f: F) -> Self
This is just slightly wierd, however if you have a bunch of borrowed forms of members of the set, and you want to look at the real entries and possibly add/update/remove them, then this method is for you.
sourcepub fn insert(&self, k: K) -> (Self, bool)
pub fn insert(&self, k: K) -> (Self, bool)
return a new set with k inserted into it. If k already exists in the old set return true, else false. If the element already exists in the set memory will not be allocated.
sourcepub fn insert_cow(&mut self, k: K) -> bool
pub fn insert_cow(&mut self, k: K) -> bool
insert k
with copy on write semantics. if self
is a unique
reference to the set, then k will be inserted in
place. Otherwise, only the parts of the set necessary to
insert k
will be copied, and then the copies will be
mutated. self will share all the parts that weren’t modfied
with any previous clones.
sourcepub fn contains<'a, Q>(&'a self, k: &Q) -> bool
pub fn contains<'a, Q>(&'a self, k: &Q) -> bool
return true if the set contains k, else false. Runs in log(N) time and constant space. where N is the size of the set.
sourcepub fn get<'a, Q>(&'a self, k: &Q) -> Option<&K>
pub fn get<'a, Q>(&'a self, k: &Q) -> Option<&K>
return a reference to the item in the set that is equal to the given value, or None if no such value exists.
sourcepub fn remove<Q: Sized + Ord>(&self, k: &Q) -> (Self, bool)where
K: Borrow<Q>,
pub fn remove<Q: Sized + Ord>(&self, k: &Q) -> (Self, bool)where
K: Borrow<Q>,
return a new set with k removed. Runs in log(N) time and log(N) space, where N is the size of the set
sourcepub fn remove_cow<Q: Sized + Ord>(&mut self, k: &Q) -> boolwhere
K: Borrow<Q>,
pub fn remove_cow<Q: Sized + Ord>(&mut self, k: &Q) -> boolwhere
K: Borrow<Q>,
remove k
from the set in place with copy on write semantics
(see insert_cow
). return true if k
was in the set.
sourcepub fn union(&self, other: &Set<K, SIZE>) -> Self
pub fn union(&self, other: &Set<K, SIZE>) -> Self
return the union of 2 sets. Runs in O(log(N) + M) time and space, where N is the largest of the two sets, and M is the number of chunks that intersect, which is roughly proportional to the size of the intersection.
§Examples
use core::iter::FromIterator;
use self::immutable_chunkmap::set::SetM;
let s0 = SetM::from_iter(0..10);
let s1 = SetM::from_iter(5..15);
let s2 = s0.union(&s1);
for i in 0..15 {
assert!(s2.contains(&i));
}
sourcepub fn intersect(&self, other: &Set<K, SIZE>) -> Self
pub fn intersect(&self, other: &Set<K, SIZE>) -> Self
return the intersection of 2 sets. Runs in O(log(N) + M) time and space, where N is the smallest of the two sets, and M is the number of intersecting chunks.
§Examples
use core::iter::FromIterator; use self::immutable_chunkmap::set::SetM;
let s0 = SetM::from_iter(0..100); let s1 = SetM::from_iter(20..50); let s2 = s0.intersect(&s1);
assert!(s2.len() == 30); for i in 0..100 { if i < 20 || i >= 50 { assert!(!s2.contains(&i)); } else { assert!(s2.contains(&i)); } }
sourcepub fn diff(&self, other: &Set<K, SIZE>) -> Selfwhere
K: Debug,
pub fn diff(&self, other: &Set<K, SIZE>) -> Selfwhere
K: Debug,
Return the difference of two sets. Runs in O(log(N) + M) time and space, where N is the smallest of the two sets, and M is the number of intersecting chunks.
§Examples
use core::iter::FromIterator;
use self::immutable_chunkmap::set::SetM;
let s0 = SetM::from_iter(0..100);
let s1 = SetM::from_iter(0..50);
let s2 = s0.diff(&s1);
assert!(s2.len() == 50);
for i in 0..50 {
assert!(!s2.contains(&i));
}
for i in 50..100 {
assert!(s2.contains(&i));
}
sourcepub fn range<'a, Q, R>(&'a self, r: R) -> SetIter<'a, R, Q, K, SIZE> ⓘ
pub fn range<'a, Q, R>(&'a self, r: R) -> SetIter<'a, R, Q, K, SIZE> ⓘ
return an iterator over the subset of elements in the set that are within the specified range.
The returned iterator runs in O(log(N) + M) time, and constant space. N is the number of elements in the tree, and M is the number of elements you examine.
if lbound >= ubound the returned iterator will be empty
Trait Implementations§
source§impl<K, const SIZE: usize> FromIterator<K> for Set<K, SIZE>
impl<K, const SIZE: usize> FromIterator<K> for Set<K, SIZE>
source§fn from_iter<T: IntoIterator<Item = K>>(iter: T) -> Self
fn from_iter<T: IntoIterator<Item = K>>(iter: T) -> Self
source§impl<'a, K, const SIZE: usize> IntoIterator for &'a Set<K, SIZE>
impl<'a, K, const SIZE: usize> IntoIterator for &'a Set<K, SIZE>
source§impl<K, const SIZE: usize> Ord for Set<K, SIZE>
impl<K, const SIZE: usize> Ord for Set<K, SIZE>
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl<K, const SIZE: usize> PartialOrd for Set<K, SIZE>
impl<K, const SIZE: usize> PartialOrd for Set<K, SIZE>
impl<K, const SIZE: usize> Eq for Set<K, SIZE>
Auto Trait Implementations§
impl<K, const SIZE: usize> Freeze for Set<K, SIZE>
impl<K, const SIZE: usize> RefUnwindSafe for Set<K, SIZE>where
K: RefUnwindSafe,
impl<K, const SIZE: usize> Send for Set<K, SIZE>
impl<K, const SIZE: usize> Sync for Set<K, SIZE>
impl<K, const SIZE: usize> Unpin for Set<K, SIZE>
impl<K, const SIZE: usize> UnwindSafe for Set<K, SIZE>where
K: RefUnwindSafe,
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
)