首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >实现__hash__()的正确和好的方法是什么?

实现__hash__()的正确和好的方法是什么?
EN

Stack Overflow用户
提问于 2010-05-26 06:56:47
回答 6查看 91.1K关注 0票数 197

什么是实现__hash__()的正确且好的方法

我说的是一个函数,它返回一个哈希码,然后用来将对象插入哈希表,也就是字典。

由于__hash__()返回一个整数,并用于将对象“打包”到哈希表中,因此我假设返回的整数的值对于公共数据应该是均匀分布的(以最小化冲突)。获得这样的值的好做法是什么?碰撞是一个问题吗?在我的例子中,我有一个小类,它充当容器类,包含一些整数、一些浮点数和一个字符串。

EN

Stack Overflow用户

发布于 2010-05-26 07:11:52

取决于您返回的哈希值的大小。这是一个简单的逻辑,如果你需要根据四个32位整数的哈希返回一个32位整数,你会得到冲突。

我更喜欢位操作。例如,下面的C伪代码:

代码语言:javascript
运行
复制
int a;
int b;
int c;
int d;
int hash = (a & 0xF000F000) | (b & 0x0F000F00) | (c & 0x00F000F0 | (d & 0x000F000F);

这样的系统也可以用于浮点数,如果您只是将它们作为位值,而不是实际表示浮点值,可能会更好。

对于字符串,我几乎不知道。

票数 0
EN
查看全部 6 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2909106

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档