往期回顾:
本期看点(技巧类用【技】表示,易错点用【易】表示):
正文开始:
在高级编程语言中,string类型的底层定义都大致相同,通常情况下,string类型是由字符数组或字符指针来定义的。
一种常见的实现是使用字符数组来存储字符串。字符数组是一个连续的内存区域,其中每个元素存储一个字符。字符串的内容被存储在字符数组中,以字符的序列形式表示。通常,字符串以空字符(‘\0’)结尾,用于标识字符串的结束。这种实现方式在C语言中比较常见。
另一种常见的实现是使用字符指针来定义字符串。在这种实现中,字符串被表示为一个指向字符数组的指针。该指针指向字符串的第一个字符,然后通过连续访问指针所指向的内存位置,可以遍历整个字符串。这种实现方式在C++和Java等高级语言中比较常见。
而读取字符串长度通常通过使用特定的函数或方法来实现。具体的方法可能会依赖于所使用的编程语言。
但是,英文字符和中文字符各自默认占的字节数与所使用的编码方式有关:
在Go语言中,rune
是表示Unicode码点类型的别名。Go语言使用rune
类型来处理Unicode字符,以便更好地支持多种语言和字符集。在处理字符串时,可以将字符串看作是由一系列rune
组成的序列。通过遍历字符串的每个rune
,可以对字符串中的每个字符进行处理,而无需关心具体的字节表示。
下面是一个使用rune
类型的简单示例:
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-by-example):
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)
}
})
}
}
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)
大家可以对号入座下哈~
需要注意的是,切片截取操作返回的是一个新的切片,原始切片不会被修改。截取操作可以灵活组合使用,以达到所需的切片截取效果。
此外,需要注意的是,在进行切片截取操作时,要确保切片的索引在有效范围内,否则会导致运行时错误。