Go语言开发小技巧&易错点100例(十)

2023-11-24 22:52:27 浏览数 (1)

往期回顾:

  • 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类型是由字符数组或字符指针来定义的。

  • 一种常见的实现是使用字符数组来存储字符串。字符数组是一个连续的内存区域,其中每个元素存储一个字符。字符串的内容被存储在字符数组中,以字符的序列形式表示。通常,字符串以空字符('')结尾,用于标识字符串的结束。这种实现方式在C语言中比较常见。
  • 另一种常见的实现是使用字符指针来定义字符串。在这种实现中,字符串被表示为一个指向字符数组的指针。该指针指向字符串的第一个字符,然后通过连续访问指针所指向的内存位置,可以遍历整个字符串。这种实现方式在C 和Java等高级语言中比较常见。

而读取字符串长度通常通过使用特定的函数或方法来实现。具体的方法可能会依赖于所使用的编程语言。

但是,英文字符和中文字符各自默认占的字节数与所使用的编码方式有关

  1. ASCII码中,一个英文字母(不分大小写)占一个字节的空间。
  2. 在UTF-8编码中,一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。
  3. 在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 = % vn", arr1)
	fmt.Printf("arr2 = % vn", arr2)

	arr3 := append(arr1, arr2...)
	fmt.Printf("arr3 = % vn", arr3)

	arr1p := arr1[:2]
	arr2p := arr2[2:]
	fmt.Printf("arr1p = % vn", arr1p)
	fmt.Printf("arr2p = % vn", arr2p)

	arr3p := arr3[1:3]
	fmt.Printf("arr3p = % vn", 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)

大家可以对号入座下哈~

需要注意的是,切片截取操作返回的是一个新的切片,原始切片不会被修改。截取操作可以灵活组合使用,以达到所需的切片截取效果。

此外,需要注意的是,在进行切片截取操作时,要确保切片的索引在有效范围内,否则会导致运行时错误。

我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

0 人点赞