什么是实现__hash__()的正确且好的方法
我说的是一个函数,它返回一个哈希码,然后用来将对象插入哈希表,也就是字典。
由于__hash__()返回一个整数,并用于将对象“打包”到哈希表中,因此我假设返回的整数的值对于公共数据应该是均匀分布的(以最小化冲突)。获得这样的值的好做法是什么?碰撞是一个问题吗?在我的例子中,我有一个小类,它充当容器类,包含一些整数、一些浮点数和一个字符串。
发布于 2010-05-26 07:11:52
取决于您返回的哈希值的大小。这是一个简单的逻辑,如果你需要根据四个32位整数的哈希返回一个32位整数,你会得到冲突。
我更喜欢位操作。例如,下面的C伪代码:
int a;
int b;
int c;
int d;
int hash = (a & 0xF000F000) | (b & 0x0F000F00) | (c & 0x00F000F0 | (d & 0x000F000F);这样的系统也可以用于浮点数,如果您只是将它们作为位值,而不是实际表示浮点值,可能会更好。
对于字符串,我几乎不知道。
https://stackoverflow.com/questions/2909106
复制相似问题