Go 专栏|基础数据类型:整数、浮点数、复数、布尔值和字符串

if i == 1 || j == 2 {

fmt.Println(“equal.”)

}

位运算

位运算符包括:&|^&^<<>>

这个就不过多介绍了,平时开发过程中用到的也比较少。

浮点数

浮点类型包括两种,分别是 float32 和 float64。

浮点数字面量会被自动推断为 float64。

f := 10.0 // 自动推断为 float64

当对浮点数进行比较运算时,不能直接使用 ==!=,结果会不稳定。应该使用 math 标准库。

复数

复数类型包括两种,分别是 complex64 和 complex128。

操作复数的内置函数一共有 3 个,分别是:

  1. complex:构造一个复数。

  2. real:获取复数的实部。

  3. imag:获取复数的虚部。

// 复数

var x complex64 = 3 + 5i

var y complex128 = complex(3.5, 10)

// 分别打印实部和虚部

fmt.Println(real(x), imag(x)) // 输出 3 5

fmt.Println(real(y), imag(y)) // 输出 3.5 10

布尔值

布尔类型的关键字是 bool,有两个值,分别是: true 和 false。

ok := true

fmt.Println(ok)

布尔型和整型不能相互转换。

var e bool

e = bool(1) // 报错 cannot convert 1 (type untyped int) to type bool

iffor 语句的条件部分一定是布尔类型的值或表达式。如果之前写 Python 比较多的话,一定要注意这点,我就在这翻过车。

m := 1

// if m { // 报错 non-bool m (type int) used as if condition

// fmt.Println(“is true”)

// }

if m == 1 {

fmt.Println(“m is 1”)

}

字符串

字符串关键字是 string,也属于一种基本类型。

字符串可以直接通过字面量来初始化:

// 字符串

s1 := “hello”

s2 := “world”

使用 ` 定义不做转义的原始字符串,支持换行:

// 原始字符串

s := `row1\r\n

row2`

fmt.Println(s)

拼接字符串:

// 字符串拼接

s3 := s1 + s2

fmt.Println(s3)

获取字符串长度:

// 取字符串长度

fmt.Println(len(s3))

按索引下标来获取字符:

// 取单个字符

fmt.Println(s3[4])

字符串切片:

// 字符串切片

fmt.Println(s3[2:4])

fmt.Println(s3[:4])

fmt.Println(s3[2:])

fmt.Println(s3[:])

字符串是不可修改的,所以如果给字符串赋值的话,会报错:

// 修改报错

s3[0] = “H” // cannot assign to s3[0] (strings are immutable)

遍历字符串:

s4 := “hello 世界”

// 遍历字节数组

for i := 0; i < len(s4); i++ {

fmt.Println(i, s4[i])

}

// 输出

// 0 104

// 1 101

// 2 108

// 3 108

// 4 111

// 5 32

// 6 228

// 7 184

// 8 150

// 9 231

// 10 149

// 11 140

// 遍历 rune 数组

for i, v := range s4 {

fmt.Println(i, v)

}

// 输出

// 0 104

// 1 101

// 2 108

// 3 108

// 4 111

// 5 32

// 6 19990

// 9 30028

从结果可以看出两者的区别,第一种是以字节数组方式遍历;第二种是以 Unicode 字符方式遍历。

以字节数组方式遍历,字符类型是 byte,长度是 1。虽然字符串直观上看长度是 8,但中文字符在 UTF-8 编码中占 3 个字符,所以总长度是 12。

以 Unicode 方式遍历,字符类型是 rune。

Go 中支持两种字符类型,一个是 byte,uint8 的别名,表示 UTF-8 字符串的单个字节的值;另一个是 rune,int32 的别名,表示单个 Unicode 字符。

最后再说一点,Go 的源文件是按 UTF-8 编码的,所以我们在选择编码格式上一定要选 UTF-8,否则可能会有一些莫名其妙的错误出现。

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
文字符在 UTF-8 编码中占 3 个字符,所以总长度是 12。

以 Unicode 方式遍历,字符类型是 rune。

Go 中支持两种字符类型,一个是 byte,uint8 的别名,表示 UTF-8 字符串的单个字节的值;另一个是 rune,int32 的别名,表示单个 Unicode 字符。

最后再说一点,Go 的源文件是按 UTF-8 编码的,所以我们在选择编码格式上一定要选 UTF-8,否则可能会有一些莫名其妙的错误出现。

[外链图片转存中…(img-G69yoUFo-1726014977199)]
[外链图片转存中…(img-Xgl4KS2u-1726014977200)]

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

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值