我正在使用哈希函数murmur2
,它返回uint64
。
我希望将它存储在PostgreSQL中,它只支持BIGINT
(带符号的64位)。
由于我对数字本身不感兴趣,只是对二进制值感兴趣(因为我将它用作检测唯一性的id(我的值为~1000值,64位散列对我来说足够)我想通过“只是”更改类型将其转换为int64
。
如何以一种令编码器满意的方式做到这一点?
答案 0 :(得分:7)
您只需使用conversion类型:
i := uint64(0xffffffffffffffff)
i2 := int64(i)
fmt.Println(i, i2)
输出:
18446744073709551615 -1
将uint64
转换为int64
总是成功:它不会改变内存表示只是类型。如果您尝试将无类型的整数常量值转换为int64
:
i3 := int64(0xffffffffffffffff) // Compile time error!
这是编译时错误,因为常量值0xffffffffffffffff
(以任意精度表示)不适合int64
,因为适合int64
的最大值是{{ 1}}:
0x7fffffffffffffff