t.Parallel()适用于纯内存操作、无外部依赖和状态共享的独立测试;需在测试开头调用,子测试也可并行;禁用全局变量修改、共用临时文件等易引发竞态的行为。
在 Go 中,t.Parallel() 是提升测试执行效率的轻量级手段,它让多个测试函数在运行时由 Go 测试框架自动调度为并发执行。但要注意:它只对 独立、无共享状态、无顺序依赖 的测试函数有效,不能解决 I/O 瓶颈或竞争问题,也不能替代真正的并行逻辑测试设计。

适合加 t.Parallel() 的测试通常满足以下条件:
t.Run)之间彼此隔离,且每个子测试内部也满足上述条件必须在测试函数体开头调用 t.Parallel(),且仅对顶层测试函数或 t.Run 创建的子测试调用。调用后,该测试即被标记为可并发执行:
func TestSort(t *testing.T) {
t.Parallel() // ✅ 正确:顶层测试启用并行
data := []int{3, 1, 4, 1, 5}
sort.Ints(data)
if !sort.IntsAreSorted(data) {
t.Fatal("sort failed")
}
}
func TestMathOps(t testing.T) {
t.Parallel()
t.Run("add", func(t testing.T) {
t.Parallel() // ✅ 子测试也可并行(需确保完全独立)
if 2+2 != 4 {
t.Fatal("add failed")
}
})
t.Run("multiply", func(t testing.T) {
t.Parallel()
if 34 != 12 {
t.Fatal("multiply failed")
}
})
}
以下做法容易引发非预期行为甚至测试失败:
var counter int)后再断言——并发下值不可预测"test.tmp")——可能相互覆盖或删除initCache() 只调一次),导致后续测试读到脏数据t.Parallel() 后再调用 t.Setenv() 或修改 os.Args——其他并行测试可能同时读取,行为未定义Go 测试默认最多使用 GOMAXPROCS 个 OS 线程执行并行测试,但实际并发数还受 -p 标志限制。可通过命令行调整:
go test -p 4 # 最多同时运行 4 个并行测试 go test -p 1 # 强制串行(用于调试竞态) go test -race -p 2 # 开启竞态检测时建议降低 -p 避免误报
注意:-p 影响的是 测试函数级别 的并发调度,不是 goroutine 数量;每个测试函数内部仍可自行启动 goroutine。