strings.Contains默认大小写敏感,忽略时需统一转小写;strings.Split保留空字符串,需手动过滤;strings.Replace需指定-1才全局替换;strings.TrimSpace清除所有Unicode空白符。

strings.Contains 判断子串存在但要注意大小写敏感
默认情况下 strings.Contains 是严格区分大小写的,比如 strings.Contains("Hello", "hello") 返回 false。如果需要忽略大小写,得先统一转成小写或大写:
strings.Contains(strings.ToLower(s), strings.ToLower(sub))。注意不要直接对原字符串做
strings.ToLower 后再传给其他函数——除非你明确需要小写版本,否则额外转换会带来不必要的内存分配。
strings.Split 处理空字符串和连续分隔符的边界情况
strings.Split("a,,b", ",") 返回 []string{"a", "", "b"},中间的空字符串会被保留;而 strings.Split("", ",") 返回 []string{""},不是 nil 也不是空切片。实际解析 CSV 或配置项时,常需要手动过滤空元素:
parts := strings.Split(line, ",")
var nonEmpty []string
for _, p := range parts {
if p != "" {
nonEmpty = append(nonEmpty, p)
}
}。别依赖 len(parts) > 0 就认为有有效字段。
strings.ReplaceAll 和 strings.Replace 区分全局替换与指定次数
strings.ReplaceAll 简单粗暴,全部替换;strings.Replace 第四个参数是最大替换次数,设为 -1 才等价于 ReplaceAll。容易出错的是误用 strings.Replace 却忘了传 -1,结果只替换了第一个匹配项。例如:
// 想把所有 "old" 换成 "new" result := strings.Replace(text, "old", "new", -1) // ✅ 正确 result := strings.Replace(text, "old", "new", 1) // ❌ 只换一次。另外,这两个函数都不支持正则,要正则替换得用
regexp.ReplaceAllString。
strings.TrimSpace 的“空白”定义比想象中宽泛
strings.TrimSpace 会移除 Unicode 定义的所有空白字符(包括 \u2000–\u200a、\u3000 等全角空格),不只是 ASCII 的 ' '、'\t'、'\n'。这在处理用户从网页粘贴进来的字符串时很关键——表面看着是空格,实则是全角空格,TrimSpace 能清掉,但 strings.Trim(text, " ") 清不掉。如果只要处理 ASCII 空格制表符换行,应该显式用 strings.Trim 并传入指定字符集:
strings.Trim(text, " \t\n\r\f\v")。混用
TrimSpace 和自定义 Trim 容易导致逻辑不一致。










