当前位置:网站首页>本周小贴士#136:无序容器
本周小贴士#136:无序容器
2022-07-07 15:39:00 【-飞鹤-】
TotW#136最初发表于2017年6月23日
由Matt Kulukundis创作
“有时,当材料真的很好时,你会对自己寄予期望,以使其成为最好的节目。你不只是提供规则的哈希,接着做你的工作,然后回家。”-彼得.丁拉基
长话短说,有关官方最新的推荐,请看https://abseil.io/docs/cpp/guides/container。本贴士介绍新类型,但不是规范的参考。
介绍absl:_hash_map
城镇出现了一个新的关联容器系列。他们自夸提高效率并提供早于C++17的访问。他们也对开发者提供直接控制其实现和默认的哈希函数,这对于代码库的长远发展是重要的。新代码应该优先这些类型而不是std::unordered_map。在该系统中的所有map和set有与std::unordered_map相同的API,所以很容易转换到它们。
对于每个absl::_hash_map而言,这里同样也有一个absl::_hash_set;但是,这些图表将只描述map的情况,并且我们也常提到的只是map。
absl::flat_hash_map 和 absl::flat_hash_set
这些应该是你的默认选择。他们存储他们的value_type到主数组中。因为当它们重新散时移动数据,元素无法使得指针稳定。如果你需要指针稳定或者你的值很大,请考虑使用absl::node_hash_map代替,或者 Absl::flat_has-mak<Key,std::unique_ptr>。
absl::node_hash_map 和 absl::node_hash_set
敬告:因为在重新散列像map[“a”]=map[“b”]之后将访问无效的内存,指针不稳定。
它们主数组之外分配它们的value_type(如std::unordered_map)。由于这些独立的分配,它们为存储的数据提供指针稳定性(存储在map中的对象的地址不会改变),并且空槽只需要8个字节。另外,它们能够存储既不能移动也不能复制的东西。
我们通常建议您使用 absl::flat_hash_map<K, std::unique_ptr> 而不是 absl::node_hash_map<K, V>,对于 node_hash_set 也是如此。
边栏推荐
- SlashData开发者工具榜首等你而定!!!
- Flask build API service SQL configuration file
- L1-027 出租(Lua)
- 99% of users often make mistakes in power Bi cloud reports
- Share the latest high-frequency Android interview questions, and take you to explore the Android event distribution mechanism
- 【TPM2.0原理及应用指南】 12、13、14章
- LeetCode 1477. Find two subarrays with sum as the target value and no overlap
- Shallow understanding Net core routing
- 【饭谈】如何设计好一款测试平台?
- redis主从、哨兵主备切换搭建一步一步图解实现
猜你喜欢
随机推荐
自定义View必备知识,Android研发岗必问30+道高级面试题
智慧物流平台:让海外仓更聪明
LeetCode 1155. N ways to roll dice one question per day
[image sensor] correlated double sampling CDs
Flask build API service SQL configuration file
[source code interpretation] | source code interpretation of livelistenerbus
LeetCode 1654. The minimum number of jumps to get home one question per day
Seaborn data visualization
国内首创!Todesk将RTC技术融入远程桌面,画质更清晰操作更流畅
服务器彻底坏了,无法修复,如何利用备份无损恢复成虚拟机?
《世界粮食安全和营养状况》报告发布:2021年全球饥饿人口增至8.28亿
LeetCode 535(C#)
科普达人丨一文弄懂什么是云计算?
DNS 系列(一):为什么更新了 DNS 记录不生效?
Solid function learning
Matplotlib绘图界面设置
【黄啊码】为什么我建议您选择go,而不选择php?
[Seaborn] combination chart: facetgrid, jointgrid, pairgrid
[Huang ah code] Why do I suggest you choose go instead of PHP?
LeetCode 1774. The dessert cost closest to the target price is one question per day









