go语言中 字符串 切片 使用 str[start:end]语法,从 start 到 end(不包含)提取子串,如 s:=”hello”; sub:=s[1:4]得 "ell";支持省略索引,s[:3]等价于 s[0:3],s[2:]从索引 2 到末尾,s[:]复制整个字符串;因字符串不可变,切片会创建新字符串;处理中文需转为 rune 切片避免乱码,如 runes:=[]rune(“ 你好世界 ”); chineseSub:=String(runes[0:2])得 " 你好 ";常用操作包括取前 N 字符 string([]rune(s)[:n])、后 N 字符 string([]rune(s)[len([]rune(s))-n:])、去首尾 s[1:len(s)-1];操作前应检查长度防越界 panic。

Go 语言 中对字符串的切片操作非常直观,直接使用索引范围即可提取子串。字符串在 Go 中是不可变的,因此切片操作会创建一个新的字符串,而不是修改原字符串。
基本字符串切片语法
使用 str[start:end] 的形式进行切片,表示从索引 start 开始(包含),到 end 结束(不包含)。
例如:
s := "hello"-
sub := s[1:4]得到"ell"
支持省略起始或结束索引:
立即学习“go 语言免费学习笔记(深入)”;
-
s[:3]等价于s[0:3] -
s[2:]从索引 2 一直到末尾 -
s[:]复制整个字符串
处理中文字符(UTF-8编码)
Go 的字符串默认以 UTF-8编码 存储,一个中文字符通常占 3 个 字节 。直接按 字节 切片可能导致字符被截断,出现乱码。
正确做法是先将字符串转为 rune 切片:
runes := []rune(" 你好世界 ")-
chineseSub := string(runes[0:2])得到" 你好 "
通过转换为 rune 可以按字符而非字节进行切片,避免乱码问题。
常用切片操作示例
实际开发中常见的需求:
- 获取前 N 个字符:
string([]rune(s)[:n]) - 获取后 N 个字符:
string([]rune(s)[len([]rune(s))-n:]) - 去掉首尾字符:
s[1:len(s)-1](注意边界判断)
如果不确定长度,操作前应检查字符串长度,防止越界 panic。
基本上就这些。掌握字节与字符的 区别,就能安全地进行各种字符串切片操作。


