使用反射可动态解析结构体字段及json标签,实现自定义JSON序列化;2. 通过reflect遍历字段,结合标签和零值判断,构建含非零值的map;3. 支持嵌套结构体与指针的递归处理;4. 适用于字段过滤、运行时解析等场景,灵活性高但性能低于标准库。

在Go语言中,JSON序列化通常通过
encoding/json
通过
reflect.Value
reflect.Type
json:"name"
示例结构体:
type User struct {
Name string `json:"name"`
Age int `json:"age,omitempty"`
City string `json:"city,omitempty"`
}
使用反射读取字段:
val := reflect.ValueOf(user)
typ := reflect.TypeOf(user)
for i := 0; i < val.NumField(); i++ {
field := val.Field(i)
fieldType := typ.Field(i)
jsonTag := fieldType.Tag.Get("json")
if jsonTag == "" || jsonTag == "-" {
continue
}
tagName := jsonTag
if idx := strings.Split(jsonTag, ","); len(idx) > 0 {
tagName = idx[0]
}
fmt.Printf("%s: %v\n", tagName, field.Interface())
}
结合反射和
map[string]interface{}omitempty
关键判断逻辑:
field.IsZero()
field.Interface() == reflect.Zero(field.Type()).Interface()
omitempty
json
示例代码片段:
result := make(map[string]interface{})
for i := 0; i < val.NumField(); i++ {
field := val.Field(i)
fieldType := typ.Field(i)
tag := fieldType.Tag.Get("json")
if tag == "" || tag == "-" {
continue
}
parts := strings.Split(tag, ",")
key := parts[0]
omitEmpty := false
for _, opt := range parts[1:] {
if opt == "omitempty" {
omitEmpty = true
}
}
if omitEmpty && field.IsZero() {
continue
}
result[key] = field.Interface()
}
反射还能处理复杂类型,如嵌套结构体或指针字段。需要递归调用或解引用。
例如,字段是指针:
if field.Kind() == reflect.Ptr && !field.IsNil() {
field = field.Elem()
}
if field.Kind() == reflect.Struct {
// 递归处理子结构体
result[key] = structToMap(field)
} else {
result[key] = field.Interface()
}
这种动态序列化适合以下场景:
注意:反射性能低于标准
json.Marshal
基本上就这些。通过反射,你可以完全掌控结构体到JSON的转换过程,实现动态、条件化序列化。虽然灵活,但要小心处理类型和边界情况。
以上就是怎样用反射实现JSON序列化 动态解析结构体字段案例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号