在 Go 中,reflect.Value 修改数组元素需满足可寻址且可设置,应通过 reflect.ValueOf(&arr).Elem() 获取可设置值,再用 Index(i).Set() 修改,注意类型严格匹配并运行时检查。
在 Go 中,reflect.Value 可以修改数组元素,但必须满足一个前提:该 reflect.Value 是可寻址的(CanAddr() 返回 true),且是可设置的(CanSet() 返回 true)。直接对非地址值(如字面量、函数返回值)调用 reflect.Value.Elem() 或 Index() 后尝试 Set() 会 panic。
只有通过指针或变量地址获取的 reflect.Value 才能被修改。常见正确做法是:
reflect
.ValueOf(&arr).Elem() 获取数组的可设置 Valuereflect.ValueOf(arr)(只读副本,CanSet() == false)获取数组的可设置 Value 后,调用 Index(i) 得到对应位置的元素 Value,再用 Set() 赋新值。注意类型必须严格匹配:
[3]int,只能用 reflect.ValueOf(42)(int 类型)赋值int64 给 int 元素赋值)会 panic示例:
arr := [3]int{10, 20, 30}
v := reflect.ValueOf(&arr).Elem() // ✅ 可设置
v.Index(1).Set(reflect.ValueOf(99)) // 修改 arr[1] 为 99
// arr 现在是 [10 99 30]
二维数组(如 [2][3]int)需链式调用 Index():
v.Index(0).Index(2).Set(...) 表示第 0 行第 2 列reflect.ValueOf(slice) 默认可寻址)[]int{1,2})且未取地址,则不可设;稳妥起见仍建议用 &slice
实际使用中建议增加安全检查:
v.Kind() == reflect.Array 确认是数组v.CanAddr() && v.CanSet() 判断是否可修改v.Index(i).CanSet() 和 v.Index(i).Type().AssignableTo(targetType) 校验索引项是否可赋值及类型兼容不复杂但容易忽略。