0

0

Golang的encoding/json库如何工作 结构体标签与序列化技巧

P粉602998670

P粉602998670

发布时间:2025-08-15 17:32:01

|

594人浏览过

|

来源于php中文网

原创

Go语言的encoding/json库通过反射实现Go值与JSON互转,支持基本类型、结构体、切片、映射等,其中结构体最常用。通过结构体标签(如json:"name")可自定义JSON字段名,首字母大写的字段才能被导出。常用标签选项包括:omitempty表示零值时省略字段,-表示完全忽略字段,string表示以字符串形式编码。嵌套结构体可递归处理,匿名字段的字段会被提升至外层。反序列化时优先匹配json标签名,无标签则匹配字段原名,未定义的JSON字段默认被忽略,可通过map或自定义UnmarshalJSON捕获。实现json.Marshaler和Unmarshaler接口可自定义序列化逻辑,如格式化时间输出。掌握标签和接口定制即可灵活处理JSON。

golang的encoding/json库如何工作 结构体标签与序列化技巧

Go语言的

encoding/json
库通过反射机制将Go值与JSON数据之间相互转换。它能处理基本类型、结构体、切片、映射等,其中结构体是最常用的序列化目标。理解结构体标签(struct tags)和一些序列化技巧,能帮助你更灵活地控制JSON的输出和解析行为。

结构体标签控制JSON字段名

结构体字段可以通过

json
标签自定义JSON中的键名。默认情况下,字段名会直接转为JSON键,但首字母大写字段才能被导出(序列化)。

示例:

type User struct {
    Name string `json:"name"`
    Age  int    `json:"age"`
}

序列化时,

Name
字段会变成
"name"
,而不是
"name"
。如果不写标签,会使用字段原名;如果字段名是小写(如
Name
),则不会被序列化。

常用标签选项

除了指定字段名,

json
标签还支持多个选项,用逗号分隔:

立即学习go语言免费学习笔记(深入)”;

  • omitempty:如果字段值为零值(如空字符串、0、nil等),则在JSON中省略该字段
  • -:完全忽略该字段,不参与序列化和反序列化
  • string:强制将某些类型(如数字或布尔)以字符串形式编码
示例:

type Product struct {
    ID       int     `json:"id"`
    Title    string  `json:"title"`
    Price    float64 `json:"price,omitempty"`
    Secret   string  `json:"-"`
    Count    int     `json:"count,string,omitempty"`
}

Price
为0时,不会出现在JSON中。
Secret
字段则完全被忽略。
Count
会被编码为字符串,即使它是整数。

嵌套结构与匿名字段的处理

结构体可以嵌套,

encoding/json
会递归处理。匿名字段(内嵌结构体)的字段会被“提升”到外层结构体中。

Packify
Packify

Packify 是一个创新的AI包装设计工具

下载
示例:

type Address struct {
    City  string `json:"city"`
    State string `json:"state"`
}

type Person struct {
    Name    string  `json:"name"`
    Address         // 匿名字段
    ZipCode string  `json:"zip"`
}

序列化

Person
时,
City
State
会直接出现在JSON顶层,如同它们是
Person
的字段。

反序列化时的字段匹配规则

反序列化时,库会根据JSON键名匹配结构体字段。匹配过程不区分标签顺序,但必须满足:

  • 字段必须是导出的(首字母大写)
  • 使用
    json
    标签优先匹配标签名
  • 若无标签,则匹配字段原名

如果JSON包含结构体中不存在的字段,默认会忽略。若想捕获未知字段,可使用

map[string]interface{}
或自定义
UnmarshalJSON
方法。

自定义序列化行为

某些类型(如时间、自定义枚举)可能需要特殊处理。实现

json.Marshaler
json.Unmarshaler
接口可控制序列化逻辑。

示例:格式化时间

type CustomTime struct {
    time.Time
}

func (ct *CustomTime) MarshalJSON() ([]byte, error) {
    return json.Marshal(ct.Time.Format("2006-01-02"))
}

func (ct *CustomTime) UnmarshalJSON(data []byte) error {
    var s string
    if err := json.Unmarshal(data, &s); err != nil {
        return err
    }
    t, err := time.Parse("2006-01-02", s)
    if err != nil {
        return err
    }
    ct.Time = t
    return nil
}

这样,时间字段可以按指定格式输出为字符串。

基本上就这些。掌握结构体标签和接口定制,就能灵活应对大多数JSON处理场景。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

178

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

337

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

189

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

192

2025.06.17

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

3

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MongoDB 教程
MongoDB 教程

共17课时 | 2万人学习

Swoft2.x速学之http api篇课程
Swoft2.x速学之http api篇课程

共16课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号