使用reflect.Value.Interface()可获取原始值并结合类型断言安全提取;2. 通过reflect.Kind()判断类型实现分支处理;3. 修改参数需传指针并用Elem()获取指向值;4. 遍历结构体字段需检查导出性,通过Field和Tag获取字段值与标签。

在Go语言中,反射(reflect)是处理多类型参数、实现通用函数的重要手段。虽然Go不支持泛型(在1.18之前),但通过 reflect.Value 和 reflect.Type,我们可以编写能处理任意类型的通用逻辑。以下是一些实用技巧,帮助你用反射写出更灵活、健壮的通用函数。
当你接收一个 interface{} 参数时,实际传入的可能是任意类型。通过反射可以还原其底层值:
示例:
func PrintValue(x interface{}) { v := reflect.ValueOf(x) fmt.Println("Value:", v.Interface()) }通过 reflect.Value.Kind() 或 reflect.TypeOf() 判断传入数据的种类,进行差异化处理:
立即学习“go语言免费学习笔记(深入)”;
示例:处理基础类型
func Format(x interface{}) string { v := reflect.ValueOf(x) switch v.Kind() { case reflect.Int: return fmt.Sprintf("Int: %d", v.Int()) case reflect.String: return fmt.Sprintf("String: %s", v.String()) case reflect.Slice: return fmt.Sprintf("Slice length: %d", v.Len()) default: return fmt.Sprintf("Unsupported type: %s", v.Kind()) } }反射中如果要修改原始值,必须传入指针,否则会 panic:
示例:修改整数
func SetToZero(x interface{}) { v := reflect.ValueOf(x) if v.Kind() != reflect.Ptr { panic("expected pointer") } v.Elem().Set(reflect.Zero(v.Elem().Type())) } // 调用:i := 5; SetToZero(&i) // i 变为 0反射常用于序列化、校验等场景,需访问结构体字段名、值和标签:
示例:打印结构体字段与 json 标签
func PrintStructTags(v interface{}) { rv := reflect.ValueOf(v) if rv.Kind() == reflect.Ptr { rv = rv.Elem() } if rv.Kind() != reflect.Struct { return } rt := rv.Type() for i := 0; i基本上就这些。Go反射虽强大,但性能较低,应避免高频调用。建议在配置解析、ORM、通用序列化等场景中谨慎使用,优先考虑接口或泛型(Go 1.18+)替代方案。理解 Kind 与 Type 的区别、指针处理、字段可访问性等细节,能让你写出更安全的通用函数。
以上就是Golang反射通用函数 处理多类型参数技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号