
在 go 单元测试中,需用切片字面量(如 `[]int{2, 3, 7}`)初始化结构体字段,而非数组字面量(`[3]int{2,3,7}`);且切片不可直接用 `!=` 比较,应使用 `reflect.deepequal` 进行深度相等判断。
Go 语言中,数组(array)和切片(slice)是两种完全不同的类型,语法和语义均有显著区别。你在测试用例中写的是 {15, [3,5]},这存在两个关键错误:
- 语法错误:[3,5] 不是合法的 Go 字面量——数组字面量必须显式声明长度和类型,例如 [2]int{3,5};而你期望的是动态长度的切片,应写作 []int{3, 5};
- 逻辑错误:Go 不支持切片间的直接相等比较(observed != test.expected 会编译失败),因为切片是引用类型,其底层结构包含指针、长度和容量,== 仅对数组、基本类型、指针等可比较类型有效。
✅ 正确写法如下(已修正语法 + 深度比较):
package primeFactor
import (
"reflect"
"testing"
)
var testCases = []struct {
p int
expected []int
}{
{15, []int{3, 5}}, // ✅ 切片字面量:[]T{...}
{26, []int{2, 13}},
{37, []int{37}},
{42, []int{2, 3, 7}},
}
func TestPrimeFactor(t *testing.T) {
for _, test := range testCases {
observed := PrimeFactor(test.p)
if !reflect.DeepEqual(observed, test.expected) { // ✅ 使用 DeepEqual 判断逻辑相等
t.Errorf("For p = %d, expected %v, got %v",
test.p, test.expected, observed)
}
}
}⚠️ 注意事项:
- reflect.DeepEqual 是标准库中安全、通用的深度比较方案,适用于嵌套结构、切片、map 等不可比较类型;
- 避免自行遍历比较(易出错且冗余),除非有特殊性能或调试需求;
- 测试错误信息中建议使用 %v 而非 %t(%t 仅用于布尔值),否则会导致格式化 panic;
- 若项目允许,也可考虑引入轻量断言库(如 github.com/stretchr/testify/assert),提升可读性:assert.Equal(t, test.expected, observed)。
掌握切片字面量语法与 reflect.DeepEqual 的组合,是编写健壮 Go 单元测试的基础能力。










