整型是所有编程语言里最基础的数据类型。 Go 语言支持如下所示的这些整型类型。
需要注意的是, int 和 int32 在 Go 语言里被认为是两种不同的类型,编译器也不会帮你自动做类型转换,
比如以下的例子会有编译错误:
var value2 int32
value1 := 64 // value1 将会被自动推导为 int 类型
value2 = value1 // 编译错误
编译错误类似于:
cannot use value1 (type int) as type int32 in assignment 。
使用强制类型转换可以解决这个编译错误:
value2 = int32(value1) // 编译通过
当然,开发者在做强制类型转换时,需要注意数据长度被截短而发生的数据精度损失
(比如将浮点数强制转为整数)和值溢出(值超过转换的目标类型的值范围 时)问题。
整型的使用细节:
( 1 ) golang 整数类型分为:有符号和无符号, int 和 uint 的大小和系统有关;
( 2 ) golang 整型默认申明为 int ;
( 3 ) fmt.Printf("num 的数据类型是 %T ,占的字节数是 %d", num,unsafe.Sizeof(num))
( 4 ) golang 使用整数类型时,遵从保小不保大原则,即在保证程序正常运行的
情况下, 尽量使用占用空间小的数据类型;
( 5 ) bit :计算机中最小的存储单位, byte :计算机中基本的存储单元;
计算类型的大小 :
package main
import (
"fmt"
"unsafe"
)
func main() {
var a int ;
fmt.Printf("%T unsafe = %d\n",a,unsafe.Sizeof(a))
}
Go 语言中 unsafe.Sizeof() 函数:
1 、对不同长度的字符串, unsafe.Sizeof() 函数的返回值都为 16 ,这是因为string 类型对应一个结构体,该结构体有两个域,第一个域指向该字符串的指针,第二个域为字符串的长度,每个域占 8 个字节,但是并不包含指针指向的字符串的内容,这就解释了unsafe.Sizeof() 函数对 string 类型的返回值始终是 16 。
2 、对不同长度的数组, unsafe.Sizeof() 函数的返回值随着数组中的元素个数的增加而增加, 这是因为unsafe.Sizeof() 函数总是在编译期就进行求值,而不是在运行时,这就意味着,unsafe.Sizeof() 函数的返回值可以赋值给常量,在编译期求值,意味着可以获得数组所占的内存大小,因为数组总是在编译期就指明自己的容量,并且在以后都是 不可变的。
3 、对所含元素个数不同的切片, unsafe.Sizeof() 函数的返回值都为 24 ,这是因为对切片来说,
unsafe.Sizeof() 函数返回的值对应的是切片的描述符,而不是切片所指向的内存的大小, 因此都是24。