4 releases
0.2.0 |
|
---|---|
0.1.3 | Mar 13, 2024 |
0.1.2 | Nov 30, 2022 |
0.1.1 | Nov 30, 2022 |
0.1.0 | Mar 11, 2022 |
#721 in Data structures
154 downloads per month
11KB
181 lines
pi_densevec
重定向映射表,一个使用usize作为key的映射表
lib.rs
:
重定向映射表,一个使用usize作为key的映射表,
使用usize作为key的映射表,Vec
、HashMap
都能做到。而DenseVecMap
可以认为是这两种数据结构作为映射表时,
在性能和内存占用上的一个平衡
使用密集vec作为数据结构的Map 该数据结构的实现,始于ecs系统的需求。 ecs的实体通常由一个数字表示,系统中的实体数字一般是从小到大的、连续的、小的数字 (就像Vec中元素的偏移,小是一个相对概念,Vec的偏移一般不会达到亿、兆的层次)。 每个实体可以对应多个组件、为了追求同类组件内存空间的连续来提升性能, ecs通常把不同实体实例拥有的相同类型的组件实例放在同一个连续的数据结构中,Vec就组件的容器的一个很好的选择。 通过实体对应的数字,可以查询、删除、修改Vec中的组件(这个过程,实体数字作为偏移找到对应组件实例)。 Vec作为组件的容器时,如果所有实体或者多是实体都拥有这类组件,这将工作得很好,但是,假如我们有50个实体,仅仅0号实体和49号实体 存在该组件,其它实体不需要该组件,那么可想而知,我们需要Vec的长度为50,在第0号位置和第49号位置存在一个组件,其他位置为空。 这将大大浪费内存空间。一个替换的方案是使用HashMap作为该类组件的数据结构,但如果你追求性能,HashMap与Vec相比还是存在一定差距。 DenseVecMap为此提供一个折中的方案。其具有比HashMap更高的性能、比Vec更低的性能;比HashMap更高的内存浪费、比Vev更低的内存浪费 DenseVecMap使用两层数据结构来做到这一点。 第一层为一个VecMap: 其长度与实体长度一样,其内容为一个usize,记录一个第二层数据结构的索引 第二层为一个Vec:其长度该类组件的个数一样,其存放具体的组件数据。 查询组件时,通过实体数字,在第一层找到该数字对应位置中存放的usize,在通过该usize找到第二层中的真实数据。 删除组件时,如果组件在第二层Vec的中间位置,需要将Vec中最后一个组件放到该位置,并在第一层中改变对应的usize。 因此,可以看出,DenseVecMap依然会浪费掉48个usize(第一层中1-48的位置)。当你的组件数据并量不大时,你并没有比Vec更节省内存空间 比如,你的组件数据就是一个usize,你并没有节省内存,反而比Vec使用了更多的内存,而且相比Vec,性能也更低,此时,建议。 尽管如此,在存储的单个数据体积稍大时,DenseVecMap依然是一个十分值得考虑的数据结构。
Dependencies
~430KB