[−][src]Struct cranelift_entity::SparseMap
A sparse mapping of entity references.
A SparseMap<K, V>
map provides:
- Memory usage equivalent to
SecondaryMap<K, u32>
+Vec<V>
, so much smaller thanSecondaryMap<K, V>
for sparse mappings of largerV
types. - Constant time lookup, slightly slower than
SecondaryMap
. - A very fast, constant time
clear()
operation. - Fast insert and erase operations.
- Stable iteration that is as fast as a
Vec<V>
.
Compared to SecondaryMap
When should we use a SparseMap
instead of a secondary SecondaryMap
? First of all,
SparseMap
does not provide the functionality of a PrimaryMap
which can allocate and assign
entity references to objects as they are pushed onto the map. It is only the secondary entity
maps that can be replaced with a SparseMap
.
- A secondary entity map assigns a default mapping to all keys. It doesn't distinguish between
an unmapped key and one that maps to the default value.
SparseMap
does not requireDefault
values, and it tracks accurately if a key has been mapped or not. - Iterating over the contents of an
SecondaryMap
is linear in the size of the key space, while iterating over aSparseMap
is linear in the number of elements in the mapping. This is an advantage precisely when the mapping is sparse. SparseMap::clear()
is constant time and super-fast.SecondaryMap::clear()
is linear in the size of the key space. (Or, rather the requiredresize()
call following theclear()
is).SparseMap
requires the values to implementSparseMapValue<K>
which means that they must contain their own key.
Methods
impl<K, V> SparseMap<K, V> where
K: EntityRef,
V: SparseMapValue<K>,
[src]
K: EntityRef,
V: SparseMapValue<K>,
pub fn new() -> Self
[src]
Create a new empty mapping.
pub fn len(&self) -> usize
[src]
Returns the number of elements in the map.
pub fn is_empty(&self) -> bool
[src]
Returns true is the map contains no elements.
pub fn clear(&mut self)
[src]
Remove all elements from the mapping.
pub fn get(&self, key: K) -> Option<&V>
[src]
Returns a reference to the value corresponding to the key.
pub fn get_mut(&mut self, key: K) -> Option<&mut V>
[src]
Returns a mutable reference to the value corresponding to the key.
Note that the returned value must not be mutated in a way that would change its key. This would invalidate the sparse set data structure.
pub fn contains_key(&self, key: K) -> bool
[src]
Return true
if the map contains a value corresponding to key
.
pub fn insert(&mut self, value: V) -> Option<V>
[src]
Insert a value into the map.
If the map did not have this key present, None
is returned.
If the map did have this key present, the value is updated, and the old value is returned.
It is not necessary to provide a key since the value knows its own key already.
pub fn remove(&mut self, key: K) -> Option<V>
[src]
Remove a value from the map and return it.
pub fn pop(&mut self) -> Option<V>
[src]
Remove the last value from the map.
pub fn values(&self) -> Iter<V>
[src]
Get an iterator over the values in the map.
The iteration order is entirely determined by the preceding sequence of insert
and
remove
operations. In particular, if no elements were removed, this is the insertion
order.
pub fn as_slice(&self) -> &[V]
[src]
Get the values as a slice.
Trait Implementations
impl<'a, K, V> IntoIterator for &'a SparseMap<K, V> where
K: EntityRef,
V: SparseMapValue<K>,
[src]
K: EntityRef,
V: SparseMapValue<K>,
Iterating over the elements of a set.
Auto Trait Implementations
impl<K, V> Unpin for SparseMap<K, V> where
K: Unpin,
V: Unpin,
K: Unpin,
V: Unpin,
impl<K, V> Send for SparseMap<K, V> where
K: Send,
V: Send,
K: Send,
V: Send,
impl<K, V> Sync for SparseMap<K, V> where
K: Sync,
V: Sync,
K: Sync,
V: Sync,
impl<K, V> RefUnwindSafe for SparseMap<K, V> where
K: RefUnwindSafe,
V: RefUnwindSafe,
K: RefUnwindSafe,
V: RefUnwindSafe,
impl<K, V> UnwindSafe for SparseMap<K, V> where
K: UnwindSafe,
V: UnwindSafe,
K: UnwindSafe,
V: UnwindSafe,
Blanket Implementations
impl<T> From<T> for T
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,