pub struct SparseMap<K, V>where
    K: EntityRef,
    V: SparseMapValue<K>,{ /* private fields */ }Expand description
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 largerVtypes.
- 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. SparseMapdoes not requireDefaultvalues, and it tracks accurately if a key has been mapped or not.
- Iterating over the contents of an SecondaryMapis linear in the size of the key space, while iterating over aSparseMapis 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 required- resize()call following the- clear()is).
- SparseMaprequires the values to implement- SparseMapValue<K>which means that they must contain their own key.
Implementations§
Source§impl<K, V> SparseMap<K, V>where
    K: EntityRef,
    V: SparseMapValue<K>,
 
impl<K, V> SparseMap<K, V>where
    K: EntityRef,
    V: SparseMapValue<K>,
Sourcepub fn get(&self, key: K) -> Option<&V>
 
pub fn get(&self, key: K) -> Option<&V>
Returns a reference to the value corresponding to the key.
Sourcepub fn get_mut(&mut self, key: K) -> Option<&mut V>
 
pub fn get_mut(&mut self, key: K) -> Option<&mut V>
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.
Sourcepub fn contains_key(&self, key: K) -> bool
 
pub fn contains_key(&self, key: K) -> bool
Return true if the map contains a value corresponding to key.
Sourcepub fn insert(&mut self, value: V) -> Option<V>
 
pub fn insert(&mut self, value: V) -> Option<V>
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.
Trait Implementations§
Source§impl<'de, K, V> Deserialize<'de> for SparseMap<K, V>
 
impl<'de, K, V> Deserialize<'de> for SparseMap<K, V>
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,
 
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
    __D: Deserializer<'de>,
Source§impl<'a, K, V> IntoIterator for &'a SparseMap<K, V>where
    K: EntityRef,
    V: SparseMapValue<K>,
Iterating over the elements of a set.
 
impl<'a, K, V> IntoIterator for &'a SparseMap<K, V>where
    K: EntityRef,
    V: SparseMapValue<K>,
Iterating over the elements of a set.