Go反射调用多返回值函数时,reflect.Value.Call返回[]reflect.Value切片,需遍历并用.Interface()配合类型断言还原各返回值,错误值应优先检查。
Go语言的反射机制可以动态调用函数并获取其返回值,但要注意:函数返回多个值时,reflect.Value.Call 返回的是一个 []reflect.Value 切片,每个元素对应一个返回值。关键在于正确遍历这个切片,并按需转换类型。
使用 reflect.Value.Call 后,直接遍历返回的 []reflect.Value 即可拿到每个结果:
[]reflect.Value 类型(可用 reflect.ValueOf(x).Args... 或手动构造)results 是切片,长度等于函数声明的返回值个数result 调用 .Interface() 可转为 interface{},再类型断言还原原始类型由于反射丢失了静态类型信息,还原时需明确知道每个返回值的类型。常见做法:
func() (int, string, error)),可按索引依次断言:results[0].Interface().(int)、results[1].Interface().(string)
result.Kind() 和 result.Type() 做运行时判断.Interface() 会 panic,建议先用 .CanInterface() 检查很多 Go 函数最后一个返回值是 error,反射调用后应优先检查:
立即学习“go语言免费学习笔记(深入)”;
results[len(results)-1],判断是否为非 nil 的 errortoError(v reflect.Value) error,内部做 v.Interface() + 类型断言假设函数 divide(a, b int) (int, error):
fn := reflect.ValueOf(divide)
args := []reflect.Value{reflect.ValueOf(10), reflect.ValueOf(2)}
results := fn.Call(args)
quotient := results[0].Interface().(int),err := results[1].Interface().(error)