我正在使用哈希函數murmur2,它返回一個uint64.然后我想將它存儲在僅支持BIGINT(有符號 64 位)的PostgreSQL 中。因為我對數字本身不感興趣,而只是對二進制值感興趣(因為我將它用作 id 來檢測唯一性(我的一組值約為 1000 個值,64 位哈希對我來說就足夠了)我想int64通過“只是”更改類型將其轉換為。如何以一種令編譯器滿意的方式做到這一點?
1 回答

ibeautiful
TA貢獻1993條經驗 獲得超6個贊
您可以簡單地使用類型轉換:
i := uint64(0xffffffffffffffff)
i2 := int64(i)
fmt.Println(i, i2)
輸出:
18446744073709551615 -1
轉換uint64為int64總是成功:它不會只改變類型的內存表示。如果您嘗試將無類型整數常量值轉換為int64:
i3 := int64(0xffffffffffffffff) // Compile time error!
這是一個編譯時錯誤,因為常量值0xffffffffffffffff(以任意精度表示)不適合,int64因為適合的最大值int64是0x7fffffffffffffff:
constant 18446744073709551615 overflows int64
- 1 回答
- 0 關注
- 203 瀏覽
添加回答
舉報
0/150
提交
取消