堆管理系统的unordered_map.是否可以进行无碰撞设置
unordered_map for heap management system. Is a no-collision setup possible?
unordered_map<>
(c++11)使用哈希函数在内部组织其键值。碰撞概率非常小(1.f/std:numeric_limits<size_t>::max()
)。
是否可以将unordered_map<>
用作堆内存管理的存储容器?也就是说,如果两个元素混淆(通过碰撞),程序的稳定性就会被破坏。就我而言,这将导致在同一指针上反复调用free()
。(SIGSEGV
)。
或者冲突概率仅在搜索密钥时才重要。并且保证两个不同的键总是引用不同的值?
后续问题:假设具有标准哈希函数的unordered_map
不适合我的应用程序。如果一个人想确保不会发生冲突,并且可以将自己限制为最多size_t
个元素,是否可以提供自己的哈希函数来返回参数本身。像这样:
template<class T>
struct Hash
{
size_t operator()(T t) {
return (size_t)t;
}
}
并确保没有碰撞?
冲突仅影响性能,而不影响容器的内容。 unordered_map
采用哈希函数和相等函数。两个元素可以安全地具有相同的哈希值,如果它们比较不相等,则它们被视为不相等。它们将始终在同一个哈希桶中。大型存储桶会损害在该存储桶中查找的操作的性能。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 在C++/Linux中设置单调时钟的一些技巧
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 嵌套在类中时无法设置成员数据
- 需要帮助设置在C++中使用的Potrace
- 如何在自删除后将对象设置为nullptr
- 将指针设置为"nullptr"并不能防止双重删除?
- 如何在Ubuntu中使用cmake设置qt4
- ld:bind_at_load和-bitcode_bundle(Xcode设置ENABLE_bitcode=YES)不能
- 如何在boost beast http请求中设置http头
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 如何将这个C++哈希表转换为动态扩展和收缩,而不是使用硬设置的最大值
- 为什么文件名被设置为一个点,而不是在读取矢量中的文件名时
- 如何在24位SDL_Surface上设置像素的颜色
- std::设置自定义比较器
- 如何为 QGraphicsPixmapItem 设置鼠标碰撞框?[QT/C++]
- 堆管理系统的unordered_map.是否可以进行无碰撞设置
- 设置碰撞检测,然后在 2D 游戏中处理碰撞
- 如何在项目符号中设置碰撞对象的颜色
- 我将如何使用子弹物理库设置碰撞