5. 基本数据类型
5.1 布尔类型(bool)
布尔类型关键字是bool,布尔类型只有两个值:true和fasle,默认值为false
注意:
- 布尔类型变量的默认值为
false
。 - Go 语言中不允许将整型强制转换为布尔型.
- 布尔型无法参与数值运算,也无法与其他类型进行转换。
5.2 数值
5.2.1 整型
内置12种,分别是: byte, int, int8, int16, int32, int64, uint, uint8, uint16, uint32, uint64, uintprt
不同类型的整型必须进行强制类型转换
整型分为以下两个大类: 按长度分为:int8、int16、int32、int64 对应的无符号整型:uint8、uint16、uint32、uint64。 其中,uint8
就是我们熟知的byte
型,int16
对应C语言中的short
型,int64
对应C语言中的long
型。
类型 | 描述 |
---|---|
uint8 | 无符号 8位整型 (0 到 255) |
uint16 | 无符号 16位整型 (0 到 65535) |
uint32 | 无符号 32位整型 (0 到 4294967295) |
uint64 | 无符号 64位整型 (0 到 18446744073709551615) |
int8 | 有符号 8位整型 (-128 到 127) |
int16 | 有符号 16位整型 (-32768 到 32767) |
int32 | 有符号 32位整型 (-2147483648 到 2147483647) |
int64 | 有符号 64位整型 (-9223372036854775808 到 9223372036854775807) |
uint | 32位操作系统上就是uint32 ,64位操作系统上就是uint64 |
int | 32位操作系统上就是int32 ,64位操作系统上就是int64 |
uintptr | 无符号整型,用于存放一个指针 |
5.2.2 浮点型
浮点型用于表示包含小数点的数据。 内置2种类型:float32, float64。浮点型数据不应该使用==
, !=
比较操作,应该使用标准库math
浮点型数据格式遵循IEEE 754
标准: float32
的浮点数的最大范围约为 3.4e38
,可以使用常量定义:math.MaxFloat32
。 float64
的浮点数的最大范围约为 1.8e308
,可以使用一个常量定义:math.MaxFloat64
。
package main
import (
"fmt"
"math"
)
func main() {
fmt.Printf("%f
", math.Pi)
fmt.Printf("%.2f
", math.Pi)
}