往期回顾:
- 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
类型的简单示例:
go
func TestStrLen(t *testing.T) {
s1 := "123321"
fmt.Println(len(s1)) // 6
s2 := "一二三"
fmt.Println(len(s2)) // 9
s3 := []rune("一二三")
fmt.Println(len(s3)) // 3
}
Go优雅的Test方法
代码如下(出自go-by-example):
go
package math
import "testing"
func TestAdd(t *testing.T) {
// Define the test table
tests := []struct {
name string
inputA int
inputB int
want int
}{
{"Add 1 and 2", 1, 2, 3},
{"Add -1 and 1", -1, 1, 0},
// Add more test cases here
}
// Iterate over the test table
for _, 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语言中的切片类型支持各种截取操作,用于从一个切片中获取子序列或部分内容。这些截取操作可以通过使用切片的索引和切片操作符来实现。
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)
}
输出:
shell
=== 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)
大家可以对号入座下哈~
需要注意的是,切片截取操作返回的是一个新的切片,原始切片不会被修改。截取操作可以灵活组合使用,以达到所需的切片截取效果。
此外,需要注意的是,在进行切片截取操作时,要确保切片的索引在有效范围内,否则会导致运行时错误。