首页 > 后端开发 > Golang > 正文

Kotlin 和 Golang 中的字符串散列

WBOY
发布: 2024-02-06 10:12:12
转载
642 人浏览过

Kotlin 和 Golang 中的字符串散列

问题内容

在服务 a 中,我有一个像这样进行哈希处理的字符串:

fun string.tohash(): long {
    var hashcode = this.hashcode().tolong()
    if (hashcode < 0l) {
        hashcode *= -1
    }
    return hashcode
}
登录后复制

我想在用 golang 编写的服务 b 中复制这段代码,因此对于同一个单词,我得到完全相同的哈希值。据我从 kotlin 文档中了解到,应用的哈希返回一个 64 位整数。所以在 go 中我这样做:

func hash(s string) int64 {
    h := fnv.new64()
    h.write([]byte(s))
    v := h.sum64()
    return int64(v)
}
登录后复制

但是在进行单元测试时我没有得到相同的值。我得到:

func test_hash(t *testing.t) {
    tests := []struct {
        input  string
        output int64
    }{
        {input: "papafritas", output: 1079370635},
    }
    for _, test := range tests {
        got := hash(test.input)
        assert.equal(t, test.output, got)
    }
}
登录后复制

结果:

7841672725449611742
登录后复制

我做错了什么吗?


正确答案


Java 以及 Kotlin 使用与 Go 不同的哈希函数。

可能的选项是:

  1. 使用标准哈希函数。
  2. 在 Go 中重新实现字符串的 Java hashCode。

以上是Kotlin 和 Golang 中的字符串散列的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:stackoverflow.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!