7个版本
| 0.2.0 | 2020年8月22日 |
|---|---|
| 0.1.5 | 2020年8月19日 |
| 0.1.2 | 2020年6月14日 |
2183 in 数据结构
每月27次下载
用于 hat_trie
55KB
822 行
ahtable
这是一种数组哈希数据结构,数组在初始化时分配了特定的大小,每个元素根据哈希函数分配到每个索引。数组中的每个元素都是一个Vec。每个哈希冲突都会被推入Vec。当添加的元素数量达到一定大小时,它将通过将数组大小加倍并从旧数组移动所有旧条目到新数组来扩展数组大小。所有这些都在幕后发生。用户不会受到此类操作的影响。
如何使用
- 使用
ArrayHashBuilder::default() - 使用构建器配置数组哈希所需的所有规格
- 在实例上使用
build()方法以获取ArrayHash - 使用以下方法操作数组
put()将新数据放入数组。此方法始终放置或替换现有值。try_put()如果它尚未存在,则将新数据放入数组。get()通过哈希且可比较的键检索放入其中的值。smart_get()当key为智能指针类型时检索值。这有助于减少构建与键本身相同类型的智能指针所需的时间处理器。coerce_get()当key为可以借用为不是实现PartialEq<K> 的另一个类型的类型时检索值。remove()通过哈希且可比较的键从该数组中删除值。smart_remove()用于在key是智能指针类型时检索值。这将有助于减少构造与键本身相同类型的智能指针所需的时间处理器。coerce_remove()用于在key是可以借用为不实现PartialEq<K>的原始类型的类型时删除值。contains_iter用于测试当前数组是否包含迭代器产生的每个条目。to_builder用于从现有数组中获得具有当前规范的ArrayHashBuilder。iter()用于遍历数组条目。iter_mut()用于遍历和修改数组条目。这个迭代器不应该用来修改条目键。drain()用于获取一个迭代器,该迭代器会从该数组中持续清除所有数据。drain_with()用于获取一个迭代器,当谓词返回 true 时,从中清除一些特定条目。split_by()返回另一个数组,并将满足谓词的所有值移动到新数组中。is_hasher_eq()用于检查两个数组是否有等价的哈希器。
从 0.1 到 0.2 的破坏性更改
ArrayHash::try_put现在返回Result。当它无法插入时,返回包含给定键/值以及与给定键关联的当前值的Err。当它成功时,返回包含已放入数组的值的Ok。
从 0.1 迁移到 0.2 的指南
- 对于任何
if let Some(v) = array_hash.try_put(key, value),它将变为if let Err((key, value, cur_val) = array_hash.try_put(key, value) - 对于任何
if array_hash.try_put(key, value).is_some(),它将变为if array_hash.try_put(key, value).is_err() - 对于任何
if array_hash.try_put(key, value).is_none(),它会变成if array_hash.try_put(key, value).is_ok() - 对于任何语句
array_hash.try_put(key, value);,它会变成array_hash.try_put(key, value).unwrap() - 对于任何
let cur_v = array_hash.try_put(key, value).unwrap(),它会变成let (_, _, cur_v) = array_hash.try_put(key, value).unwrap_err()
重要提示
PartialEq的ArrayHash需要比较者和比较对象完全相同。这包括Hasher,它必须使用相同的数字进行初始化。理想的使用方法是首先填充最大的数组,然后使用ArrayHash::to_builder来构建第二个数组。如果不可能,可以考虑构建一个足够大的ArrayHash以存储所有内容,而不达到max_load_factor,然后使用ArrayHash::to_builder或克隆该ArrayHashBuilder来构建每个数组。- 存在一个方法
ArrayHash::is_hasher_eq来测试两个数组是否可以比较。如果两个数组使用不同类型的哈希器,它将立即产生编译错误。如果它使用相同的哈希器类型,但使用不同的种子,它将返回false。否则,它可以通过==运算符进行比较。 - 直接在两个数组上使用
==运算符是安全的。它将产生类似于ArrayHash::is_hasher_eq的编译错误。实际上,在PartialEq实现中,它使用ArrayHash::is_hasher_eq首先检查它是否可以比较。然而,如果两个数组使用不同的种子,即使两个数组中都有完全相同的元素,它也会始终返回 false。 - 使用
==运算符比较两个数组比使用ArrayHash::contains_iter要快得多,因为contains_iter需要为迭代返回的每个键进行哈希。该方法在两个数组使用不同类型的哈希器或由不同的ArrayHashBuilder构建时适用。
新功能
0.2.0
ArrayHash::try_put将指定的key和value放入,但并不保证一定放入。现在它返回Result。如果key和value成功放入,则返回Ok((&V)),其中&V是放入的值的引用。如果放入失败,则返回Err((K, V)),其中K是给定的key,而V是给定的值。
0.1.5
- 修复哈希缺陷。当在
ArrayHash自身上哈希时,即使两个数组相等,也可能会导致两个哈希不同。这是因为PartialEq不比较max_load_factor,而是在0.1.4哈希时使用max_load_factor来计算哈希。
0.1.4
ArrayHash和ArrayHashBuilder现在实现了Hash和PartialEqArrayHash::is_hasher_eq用于检查两个数组是否使用完全相同的哈希器。ArrayHash::coerce_get和ArrayHash::coerce_remove可以接受一个未实现PartialEq的借用类型,并使用存储的条目。ArrayHash::smart_remove与ArrayHash::smart_get是对应的,当存储和查询可以下引用到同一类型时可以使用。- 为
ArrayHashBuilder实现core::convert::From::ArrayHash。 ArrayHash::to_builder可以获取一个可以构建具有与当前ArrayHash相同规范的ArrayHashBuilder。ArrayHash::contains_iter检查这个数组是否包含给定迭代器产生的每个条目。
0.1.3
ArrayHash::get和ArrayHash::remove参数现在是泛型的,而不是固定为与键相同的类型。现在任何实现了PartialEq+Hash的类型都可以作为参数使用。ArrayHash的键和值不再需要实现克隆。原因在于需要克隆键和值的地方有两个,这两个地方都是为了分配Vec。然而,在这两个地方,都不需要对键和值进行实际的克隆。它们分配了一个空的Vec。因此,克隆空Vec对性能的影响与循环构造空Vec没有区别。因此,对库用户来说,可以减少对键/值的约束。
依赖关系
~145KB