이 글은 Go에서 Int의 최대값을 소개하는 go 언어튜토리얼 칼럼에서 소개한 글이 도움이 필요한 친구들에게 도움이 되길 바랍니다!
요약:
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와 크기가 동일하다는 것을 알고 계실 것 같습니다. code> , 플랫폼에 따라 다릅니다. 일반적으로 크기 없는 버전은 플랫폼에 따라 달라지는 "네이티브" 유형을 사용할 수 있고 더 빠른 경향이 있으므로 최대값에 가까워질 위험이 없는 경우에만 사용됩니다. <code>uint
类型的大小与uint32
或uint64
相同,具体取决于您所在的平台。通常,只有在没有接近最大值风险的情况下,才会使用无尺寸的版本,因为没有尺寸规格的版本可以使用“本机”类型,这取决于平台,并且它往往更快。
请注意,更 “快” 是因为使用非本机类型需要处理器执行额外的数学计算和边界检查,以便模拟更大或更小的整数。因此,处理器(或编译器的优化代码)性能会比添加边界检查的代码要好。
话虽如此,在某些情况下,了解您正在使用的内容仍然很有用。
“math/bits“ 包中含有以字节为单位的uint
大小(译者注:UintSize )。要确定最大值,将 1
左移许多位,再减去 1。即:(1 << bits.UintSize) - 1
请注意,在计算 uint
的最大值时,您通常需要将其显式放入一个 uint
(或更大的类型)类型变量中,否则编译器可能会失败,因为它会默认尝试将该计算分配给一个有符号int
(很明显,它不适合),所以:
const MaxUint uint = (1 << bits.UintSize) - 1
这是您问题的直接答案,但您可能对一些相关的计算感兴趣。
根据 spec,uint
和 int
的大小始终相同。
uint
32 位或 64 位
int
与uint
大小相同
因此,我们也可以使用这个常量来确定 int
的最大值,方法是采用相同的答案并除以 2
,然后减去 1
。 即:(1 << bits.UintSize) / 2 - 1
以及 int
的最小值,通过将 1
移位那么多位并将结果除以 -2
。 即:(1 << bits.UintSize) / -2
总之:
** MaxUint: ** (1 << bits.UintSize) - 1
** MaxInt: ** (1 << bits.UintSize) / 2 - 1
** MinInt: ** (1 << bits.UintSize) / -2
uint
크기(바이트)가 포함되어 있습니다(번역자 참고: UintSize). 최대값을 결정하려면 1
을 여러 자리만큼 왼쪽으로 이동하고 1을 뺍니다. 즉, (1 << bit.UintSize) - 1
uint
의 최대값을 계산할 때 일반적으로 명시적으로 입력해야 한다는 점에 유의하세요. 그렇지 않으면 기본적으로 계산을 서명된int
에 할당하려고 시도하기 때문에 컴파일러가 실패할 수 있습니다(분명히 그렇지 않습니다). 맞지 않음), 따라서: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: %d\n", mi32) fmt.Printf(" MaxInt32: %d\n", i32) fmt.Printf("MaxUint32: %d\n", ui32) fmt.Printf(" MinInt64: %d\n", mi64) fmt.Printf(" MaxInt64: %d\n", i64) fmt.Printf("MaxUint64: %d\n", ui64) fmt.Printf(" MaxUint: %d\n", ui) fmt.Printf(" MinInt: %d\n", mi) fmt.Printf(" MaxInt: %d\n", i) fmt.Println("MaxUint:", uint(math.MaxUint)) fmt.Println("MinInt:", math.MinInt) fmt.Println("MaxInt:", math.MaxInt) fmt.Println("系统架构:", runtime.Compiler, runtime.GOARCH, runtime.GOOS) fmt.Println("Int 大小:", strconv.IntSize)}이것은 귀하의 질문에 대한 직접적인 답변이지만 일부 관련 계산에 관심이 있을 수도 있습니다. 사양에 따르면uint
와int
는 항상 같은 크기입니다.
🎜🎜uint
🎜 32비트 또는 64비트 🎜🎜🎜int
🎜uint
와 동일한 크기🎜🎜🎜그래서, 우리는 또한 이 상수를 사용하여 동일한 답을2
로 나눈 다음1
을 빼서int
의 최대값을 결정할 수 있습니다. 즉,(1 🎜🎜 및 <code>1
을 이동하여int
의 최소값입니다. 그 만큼의 숫자를 입력하고 결과를-2
로 나눕니다. 즉:(1 << 비트.UintSize) / -2
🎜🎜간략히: 🎜🎜** MaxUint: **(1 << 비트.UintSize) - 1🎜🎜** MaxInt: ** <code>(1 << 비트.UintSize) / 2 - 1
🎜🎜** MinInt: **(1 << ; 비트 .UintSize) / -2
🎜🎜전체 예(아래 이미지와 동일해야 함): 🎜MinInt32: -2147483648 MaxInt32: 2147483647MaxUint32: 4294967295 MinInt64: -9223372036854775808 MaxInt64: 9223372036854775807MaxUint64: 18446744073709551615 MaxUint: 18446744073709551615 MinInt: -9223372036854775808 MaxInt: 9223372036854775807MaxUint: 18446744073709551615MinInt: -9223372036854775808MaxInt: 9223372036854775807系统架构: gc amd64 darwin Int 大小: 64🎜출력: 🎜rrreee🎜🎜🎜원본 주소: https://stackoverflow.com/questions/ 6878...🎜 🎜번역 주소 : https://learnku.com/go/t/62359🎜🎜
위 내용은 Go에서 Int의 최대값을 분석한 기사의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!