亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

故意 int 溢出

故意 int 溢出

Go
Cats萌萌 2021-12-07 09:25:44
我正在使用哈希函數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


查看完整回答
反對 回復 2021-12-07
  • 1 回答
  • 0 關注
  • 203 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號