Strings.Contains 是 go 中判断字符串是否包含子串的最直接高效方式,区分大小写,空串恒为 true,不支持正则,兼容 Unicode,性能优化良好。

在 Go 语言中,判断一个字符串是否包含另一个子串,最直接、高效的方式是使用 strings.Contains 函数。
strings.Contains 基本用法
该函数定义在 strings 包中,签名如下:
func Contains(s, substr string) bool
它接收两个字符串参数:主串 s 和待查找的子串 substr,返回 bool 类型结果,表示 substr 是否作为连续子序列出现在 s 中。
立即学习“go语言免费学习笔记(深入)”;
- 区分大小写,比如
strings.Contains("Hello", "hello")返回 false - 空字符串
""被认为包含在任意字符串中(包括空串),即strings.Contains("abc", "")返回 true - 若 substr 比 s 长,自动返回 false
简单示例代码
以下是一个可直接运行的小例子:
package main
import (
“fmt”
“strings”
)
func main() {
s := “Go is simple and powerful”
fmt.Println(strings.Contains(s, “simple”)) // true
fmt.Println(strings.Contains(s, “Simple”)) // false(大小写敏感)
fmt.Println(strings.Contains(s, "")) // true
fmt.Println(strings.Contains("", “a”)) // false
}
常见使用场景与注意事项
这个函数适合做快速存在性判断,比如配置检查、日志关键词过滤、URL 路径匹配等。
- 不支持通配符或正则,如需模糊匹配请用 regexp 包
- 若需获取子串位置,改用 strings.Index;若需统计出现次数,可用 strings.count
- 对中文、emoji 等 Unicode 字符完全兼容(Go 字符串天然以 UTF-8 存储)
- 性能良好,底层做了优化,一般无需手动实现循环查找
替代方案简要对比
虽然 strings.Contains 是首选,但有时也会看到其他写法:
-
strings.Index(s, substr) != -1—— 功能等价,但多了一次位置计算,稍低效 - 手动遍历 rune 或 byte —— 容易出错且无必要,不推荐
- 使用
strings.Fields+ 循环 —— 仅适用于单词级匹配,且语义不同
基本上就这些。用好 strings.Contains 就能覆盖绝大多数“是否包含”的需求,简洁又可靠。