在Swift中编写一个很好的Hashable实现

在Objective-C(和其他语言)中, – (NSUInteger)哈希的相对较好的认实现可能是:
- (NSUInteger)hash {
   return 31u * [self.property1 hash] + [self.property2 hash];
}

假设property1和property2都返回hash值的好值。

这在Swift的等价var hashValue:在其Hashable协议中定义的Int方法不起作用。

相当的Swift代码很可能会溢出,这是Swift中的运行时错误

var hashValue: Int {
    return 31 * property1.hashValue + property2.hashValue // overflow-tastic
}

所以我的问题是,在Swift中生成散列值(实现Hashable)的最佳技术是什么?我应该使用XOR吗?虽然我的理解是XOR不是创建统一散列分布的理想选择。也许更奇特的东西?

如Fabian Kreiser所建议的,可以使用overflow操作符来制作hashValue方法,如下所示:
var hashValue: Int {
    return (31 &* property1.hashValue) &+ property2.hashValue 
}

值仍然溢出,但至少它不会崩溃

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...