Go语言基础-数据类型-整型,你头秃都没想到还能这样吧

89 阅读5分钟

int nint

特殊类型:

Unicode字符rune 类型等价于int32

byte等价于uint8

uintptr ,是无符号整型

2. 整数类型的取值范围及内存占用

各数据类型的取值范围及内存占用情况:

在这里插入图片描述

注意: int 和uint的区别就是一个u, 有u表示无符号,没有U表示有符号。

我们可以这么理解:

以 int8 和 uint8 举例,8 代表 8个bit,能表示的数值个数有 2^8 = 256

int8 是有符号,既可以正数,也可以负数,那怎么办?对半分呗,-128-127,也刚好 256个数。

如果用二进制来解释的话:

一个字节为8位(bit),计算机采用二进制(0或1),即2^8表数范围。

  • 有符号的int8表示为-128 ~ 127。下图bit7为符号位,最大值为bit0至bit6均为1,

    ,所以这里是2的七次方-1,即127;由于存在+0和-0,因此将 -0位赋值给负数,因此最小值为-128。

  • 无符号uint8表示为0 ~ 255。无符号最大值为bit0至bit7均为1,故为2的8次方-1 等于255

在这里插入图片描述

3.整数类型的案例

案例一 int类型


package main

import "fmt"

func main() {

var num1 int = 1

var num2 int8 = 127



fmt.Println(num1,num2)



}



输出结果

在这里插入图片描述

案例二 int8的取值范围测试

int8的 取值范围为-128-127, 当我们取值为-128 和127时正常运行,当我们选取超出这个范围的则会报溢出

正常取值时:


package main

import "fmt"

func main() {

var num1 int8 = -128

var num2 int8 = 127



fmt.Println(num1,num2)



}



执行结果:

在这里插入图片描述

超出范围时


package main

import "fmt"

func main() {

var num1 int8 = -128

var num2 int8 = 128



fmt.Println(num1,num2)



}



执行结果

在这里插入图片描述

4. 整形的注意事项

1) Golang各证书类型分为有符号和无符号,int、uint的大小和系统有关

2)Golang的整型默认声明为int型

3)查看某个变量的字节大小(unsafe.Sizeof)和数据类型(fmt.Printf->%T)

4)Golang程序中整型变量使用时,遵守保小不保大的原则,即:在保证程序正确运行下,尽量使用占用空间小的数据类型,比如年龄

5) bit是计算机中最小存储单位,byte是计算机中基本存储单元(1 byte=8 bit)

  1. 虽然int8和int16都是整型,但它们之间不可以进行运算,必须进行类型转换

7)Go语言是静态类型语言,不具备低精度向高精度自动转换功能,所以不同类型变量之间相互赋值需要进行类型转换.

5. 查看某个变量的数据类型案例


package main

import "fmt"

import "unsafe"

func main() {

var num int = 365



fmt.Printf("num 的数据类型是 %T \n", num)

var  n int64 = 10 

var name = "itlaoxin"

fmt.Printf("n 的数据类型是 %T; 占用字节数是 %d \n", n, unsafe.Sizeof(n))

fmt.Printf("name 的数据类型是 %T; 占用字节数是 %d \n", name, unsafe.Sizeof(name))



}



输出结果:

在这里插入图片描述

6. 类型转换案例

案例一


package main

import "fmt"



func main() {

var  a int = 10086

var b int64  = 10010

fmt.Printf("a的数据类型为%T,a的值为%d\n",a ,a)

fmt.Printf("b的数据类型为%T,b的值为%d\n",b ,b)

fmt.Println("a+b=", int64(a)+b)



}



在这里插入图片描述

案例二


package main

import "fmt"



func main() {

pork := 35.75

weight := 10

fmt.Printf("pork的类型为:%T,pork的价格为:%.2f\n",pork,pork)

fmt.Printf("weight 的类型为: %T,weight的值为: %d\n",weight,weight)

Total_price := pork * float64(weight)

//weight默认为int类型,所以我们把weight的类型转换为float64类型,然后才能进行数学运算

fmt.Printf("猪肉的单价是 %.2f元/500克,您购买了%d斤,总价为%.2f 元人民币\n",pork,weight,Total_price)



}



img img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!