本文由go語言教程欄目給大家介紹Go 中 Int 的最大數(shù)值 ,希望對需要的朋友有所幫助!
總結(jié):
import "math/bits"const ( MaxUint uint = (1 << bits.UintSize) - 1 MaxInt int = (1 << bits.UintSize) / 2 - 1 MinInt int = (1 << bits.UintSize) / -2)
背景:
我想你知道,uint類型的大小與uint32或uint64相同,具體取決于您所在的平臺。通常,只有在沒有接近最大值風(fēng)險(xiǎn)的情況下,才會(huì)使用無尺寸的版本,因?yàn)闆]有尺寸規(guī)格的版本可以使用“本機(jī)”類型,這取決于平臺,并且它往往更快。
請注意,更 “快” 是因?yàn)槭褂梅潜緳C(jī)類型需要處理器執(zhí)行額外的數(shù)學(xué)計(jì)算和邊界檢查,以便模擬更大或更小的整數(shù)。因此,處理器(或編譯器的優(yōu)化代碼)性能會(huì)比添加邊界檢查的代碼要好。
話雖如此,在某些情況下,了解您正在使用的內(nèi)容仍然很有用。
“math/bits“ 包中含有以字節(jié)為單位的uint大小(譯者注:UintSize )。要確定最大值,將 1 左移許多位,再減去 1。即:(1 << bits.UintSize) - 1
請注意,在計(jì)算 uint 的最大值時(shí),您通常需要將其顯式放入一個(gè) uint(或更大的類型)類型變量中,否則編譯器可能會(huì)失敗,因?yàn)樗鼤?huì)默認(rèn)嘗試將該計(jì)算分配給一個(gè)有符號int(很明顯,它不適合),所以:
const MaxUint uint = (1 << bits.UintSize) - 1
這是您問題的直接答案,但您可能對一些相關(guān)的計(jì)算感興趣。
根據(jù) spec,uint 和 int 的大小始終相同。
uint32 位或 64 位
int與uint大小相同
因此,我們也可以使用這個(gè)常量來確定 int 的最大值,方法是采用相同的答案并除以 2,然后減去 1。 即:(1 << bits.UintSize) / 2 - 1
以及 int 的最小值,通過將 1 移位那么多位并將結(jié)果除以 -2。 即:(1 << bits.UintSize) / -2
總之:
** MaxUint: ** (1 << bits.UintSize) - 1
** MaxInt: ** (1 << bits.UintSize) / 2 - 1
** MinInt: ** (1 << bits.UintSize) / -2
完整示例(應(yīng)與下圖相同):
package mainimport ( "fmt" "math" "math/bits" "runtime" "strconv")func main() { var mi32 int64 = math.MinInt32 var mi64 int64 = math.MinInt64 var i32 uint64 = math.MaxInt32 var ui32 uint64 = math.MaxUint32 var i64 uint64 = math.MaxInt64 var ui64 uint64 = math.MaxUint64 var ui uint64 = (1 << bits.UintSize) - 1 var i uint64 = (1<<bits.UintSize)/2 - 1 var mi int64 = (1 << bits.UintSize) / -2 fmt.Printf(" MinInt32: %dn", mi32) fmt.Printf(" MaxInt32: %dn", i32) fmt.Printf("MaxUint32: %dn", ui32) fmt.Printf(" MinInt64: %dn", mi64) fmt.Printf(" MaxInt64: %dn", i64) fmt.Printf("MaxUint64: %dn", ui64) fmt.Printf(" MaxUint: %dn", ui) fmt.Printf(" MinInt: %dn", mi) fmt.Printf(" MaxInt: %dn", i) fmt.Println("MaxUint:", uint(math.MaxUint)) fmt.Println("MinInt:", math.MinInt) fmt.Println("MaxInt:", math.MaxInt) fmt.Println("系統(tǒng)架構(gòu):", runtime.Compiler, runtime.GOARCH, runtime.GOOS) fmt.Println("Int 大小:", strconv.IntSize)}
輸出:
MinInt32: -2147483648 MaxInt32: 2147483647MaxUint32: 4294967295 MinInt64: -9223372036854775808 MaxInt64: 9223372036854775807MaxUint64: 18446744073709551615 MaxUint: 18446744073709551615 MinInt: -9223372036854775808 MaxInt: 9223372036854775807MaxUint: 18446744073709551615MinInt: -9223372036854775808MaxInt: 9223372036854775807系統(tǒng)架構(gòu): gc amd64 darwin Int 大小: 64
原文地址:https://stackoverflow.com/questions/6878…
譯文地址:https://learnku.com/go/t/62359
站長資訊網(wǎng)