int8: 表示8位整数
size: 8 bit
range: -128 – 127
int16: 表示16位有符号整数
size: 16 bit
range: -32768 – 32767
int32: 表示32位有符号整数
size: 32 bit
range: -2147483648 – 2147483647
int64: 表示64位有符号整数
size: 64 bit
range: -9223372036854775808 – 9223372036854775807
int: 表示32位或64位整数,具体取决于底层平台。通常应该使用int
来表示整数,除非需要使用特定字节数的整数。
size: 32位系统是32位,64位系统是64位。
range: 32位系统上是:-2147483648 to 2147483647,64位系统上是:-9223372036854775808 to 9223372036854775807
package main
import "fmt"
func main() {
var a int = 89
b := 95
fmt.Println("value of a is", a, "and b is", b)
}
以上程序将输出
value of a is 89 and b is 95
在上面的程序中,a
的类型是int
,而b
的类型是从赋给它的值中推断出来的(95)。
如前所述,int
在32位系统中是32位,在64位系统中是64位。让我们验证一下这一点。
变量的类型可以使用Printf
方法中的%T
格式说明符来打印。Go有一个包unsafe
,它有一个Sizeof
函数,函数以字节为单位返回变量字节数。
包unsafe
应该谨慎使用,因为使用它的代码可能存在移植性问题。
下面的程序输出变量a
和b
的类型和字节数。%T
是打印类型的格式说明符,%d
用于打印字节数。
package main
import (
"fmt"
"unsafe"
)
func main() {
var a int = 89
b := 95
fmt.Println("value of a is", a, "and b is", b)
fmt.Printf("type of a is %T, size of a is %d", a, unsafe.Sizeof(a)) //type and size of a
fmt.Printf("\ntype of b is %T, size of b is %d", b, unsafe.Sizeof(b)) //type and size of b
}
上面的程序将输出
value of a is 89 and b is 95
type of a is int, size of a is 4
type of b is int, size of b is 4
从上面的输出中我们可以推断出a
和b
的类型是int
,它们的大小是32位(4字节)。
如果在64位系统上运行上面的程序,输出将会有所不同。在64位系统中,a
和b
占用64位(8字节)。