加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-14 05:56:36 所属栏目:百科 来源:网络整理
导读:在Objective-C(和其他语言)中, – (NSUInteger)哈希的相对较好的默认实现可能是: - (NSUInteger)hash { return 31u * [self.property1 hash] + [self.property2 hash];} 假设property1和property2都返回hash值的好值。 这在Swift的等价var hashValue:在其
在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 
}

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读