Go strings包提供纯函数式字符串操作,含Contains/IndexOf查找、Split分割、Replace替换三类核心方法,所有操作不修改原串且支持UTF-8,但需注意空分隔符panic、大小写敏感及性能优化建议。
在 Go 语言中,strings 包是处理字符串最常用、最高效的工具,它提供了大量纯函数式(不修改原字符串)的操作方法。查找、分割
和替换是日常开发中最频繁的三类操作,下面直接说明怎么用、关键点在哪、容易踩什么坑。
strings.Contains 和 strings.Index 是最常用的两个函数。前者只关心“有没有”,返回 bool;后者返回首次出现的索引(从 0 开始),没找到则返回 -1。
strings.Contains("hello world", "world") // true
pos := strings.Index("hello world", "o") // 4(第一个 o)
strings.LastIndex("hello world", "o") // 7
strings.ToLower 统一转换,或使用 strings.ContainsFold(支持 Unicode 大小写折叠)strings.Split 按指定分隔符把字符串切成 []string,简单直接,但要注意边界情况:
parts := strings.Split("a,b,c", ",") // []string{"a","b","c"}
""
strings.Split(",a,b,", ",") 得到 ["", "a", "b", ""]
strings.Fields(按任意空白字符分割,自动跳过空项)或手动过滤:parts = filterEmpty(parts)
strings.Replace 和 strings.ReplaceAll 是主力函数。区别在于是否限制替换次数:
strings.ReplaceAll("banana", "a", "x") // "bxnxnx"
strings.Replace("banana", "a", "x", 2) // "bxnxna"(第三个参数是最大替换次数)strings.Replace("abc", "", "-", -1) 会在每个字符间插入 -,结果为 "-a-b-c-"
regexp 包,strings 不支持正则Go 的字符串是只读的字节序列(底层是 struct{ptr *byte, len int}),所以 strings 所有函数都返回新字符串,原字符串不变。这意味着:
strings.Builder 累积内容strings 操作的是 UTF-8 字节,但像 len(s) 返回的是字节数而非字符数;需要字符数请用 utf8.RuneCountInString(s)