往期回顾:
- Go语言开发小技巧&易错点100例(一)
- Go语言开发小技巧&易错点100例(二)
- Go语言开发小技巧&易错点100例(三)
- Go语言开发小技巧&易错点100例(四)
- Go语言开发小技巧&易错点100例(五)
- Go语言开发小技巧&易错点100例(六)
- Go语言开发小技巧&易错点100例(七)
- Go语言开发小技巧&易错点100例(八)
- Go语言开发小技巧&易错点100例(九)
本期看点(技巧类用【技】表示,易错点用【易】表示):
- Go string的长度【易】
- Go优雅的Test方法【技】
- slice的各种截取【易】
正文开始:
Go string的长度
在高级编程语言中,string类型的底层定义都大致相同,通常情况下,string类型是由字符数组或字符指针来定义的。
-
一种常见的实现是使用字符数组来存储字符串。字符数组是一个连续的内存区域,其中每个元素存储一个字符。字符串的内容被存储在字符数组中,以字符的序列形式表示。通常,字符串以空字符(‘\0’)结尾,用于标识字符串的结束。这种实现方式在C语言中比较常见。
-
另一种常见的实现是使用字符指针来定义字符串。在这种实现中,字符串被表示为一个指向字符数组的指针。该指针指向字符串的第一个字符,然后通过连续访问指针所指向的内存位置,可以遍历整个字符串。这种实现方式在C++和Java等高级语言中比较常见。
而读取字符串长度通常通过使用特定的函数或方法来实现。具体的方法可能会依赖于所使用的编程语言。
但是,英文字符和中文字符各自默认占的字节数与所使用的编码方式有关:
- ASCII码中,一个英文字母(不分大小写)占一个字节的空间。
- 在UTF-8编码中,一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。
- 在Unicode编码中,一个英文等于两个字节,一个中文(含繁体)等于两个字节。
在Go语言中,rune
是表示Unicode码点类型的别名。Go语言使用rune
类型来处理Unicode字符,以便更好地支持多种语言和字符集。在处理字符串时,可以将字符串看作是由一系列rune
组成的序列。通过遍历字符串的每个rune
,可以对字符串中的每个字符进行处理,而无需关心具体的字节表示。
下面是一个使用rune
类型的简单示例:
func TestStrLen(t *testing.T) {s1 := "123321"fmt.Println(len(s1)) // 6s2 := "一二三"fmt.Println(len(s2)) // 9s3 := []rune("一二三")fmt.Println(len(s3)) // 3
}
Go优雅的Test方法
代码如下(出自go-by-example):
package mathimport "testing"func TestAdd(t *testing.T) {// Define the test tabletests := []struct {name stringinputA intinputB intwant int}{{"Add 1 and 2", 1, 2, 3},{"Add -1 and 1", -1, 1, 0},// Add more test cases here}// Iterate over the test tablefor _, tc := range tests {t.Run(tc.name, func(t *testing.T) {got := Add(tc.inputA, tc.inputB)if got != tc.want {t.Errorf("Add(%d, %d) = %d; want %d", tc.inputA, tc.inputB, got, tc.want)}})}
}
slice的各种截取
Go语言中的切片类型支持各种截取操作,用于从一个切片中获取子序列或部分内容。这些截取操作可以通过使用切片的索引和切片操作符来实现。
func TestSlice(t *testing.T) {arr1 := make([]string, 0)arr2 := make([]string, 0)arr1 = append(arr1, "A")arr1 = append(arr1, "B")arr1 = append(arr1, "C")arr2 = append(arr2, "a")arr2 = append(arr2, "b")arr2 = append(arr2, "c")fmt.Printf("arr1 = %+v\n", arr1)fmt.Printf("arr2 = %+v\n", arr2)arr3 := append(arr1, arr2...)fmt.Printf("arr3 = %+v\n", arr3)arr1p := arr1[:2]arr2p := arr2[2:]fmt.Printf("arr1p = %+v\n", arr1p)fmt.Printf("arr2p = %+v\n", arr2p)arr3p := arr3[1:3]fmt.Printf("arr3p = %+v\n", arr3p)
}
输出:
=== RUN TestSlice
arr1 = [A B C]
arr2 = [a b c]
arr3 = [A B C a b c]
arr1p = [A B]
arr2p = [c]
arr3p = [B C]
--- PASS: TestSlice (0.00s)
大家可以对号入座下哈~
需要注意的是,切片截取操作返回的是一个新的切片,原始切片不会被修改。截取操作可以灵活组合使用,以达到所需的切片截取效果。
此外,需要注意的是,在进行切片截取操作时,要确保切片的索引在有效范围内,否则会导致运行时错误。