0

0

如何在 Go 中正确解析 JSON 数组到自定义结构体切片

聖光之護

聖光之護

发布时间:2026-01-07 14:28:02

|

743人浏览过

|

来源于php中文网

原创

如何在 Go 中正确解析 JSON 数组到自定义结构体切片

本文详解 go 语言中将 json 数组(如 github events api 返回的数据)反序列化为 []struct 类型时的常见错误与正确实践,重点解决“type does not support indexing”问题,并提供可直接运行的初始化、解码与访问方案。

在 Go 中解析 JSON 数组到结构体切片时,一个典型误区是误用 new() 初始化自定义切片类型(如 type GITHUB_EVENT []struct{...}),导致变量实际为 *GITHUB_EVENT(即指向切片的指针),而非切片本身。此时即使 json.Unmarshal 成功写入数据,尝试通过 eventDataJSON[0] 访问元素会触发编译错误:type GITHUB_EVENT does not support indexing —— 因为指针类型不支持索引操作。

✅ 正确做法是让变量直接持有切片值(而非指针),并确保 Unmarshal 接收其地址以完成填充。推荐以下三种等效且安全的方式:

方式一:使用 var 声明(最简洁、推荐)

var eventDataJSON GITHUB_EVENT
err := json.Unmarshal([]byte(eventDataRAW), &eventDataJSON)
if err != nil {
    log.Fatal(err)
}
fmt.Println(eventDataJSON[0].Id) // ✅ 可直接索引

方式二:使用 make() 显式初始化空切片

陌言AI
陌言AI

陌言AI是一个一站式AI创作平台,支持在线AI写作,AI对话,AI绘画等功能

下载
eventDataJSON := make(GITHUB_EVENT, 0)
err := json.Unmarshal([]byte(eventDataRAW), &eventDataJSON)
if err != nil {
    log.Fatal(err)
}
fmt.Println(eventDataJSON[0].Id) // ✅ 切片已就位,可索引

方式三:避免 new() —— 若坚持用 new(),必须解引用后访问

eventDataJSON := new(GITHUB_EVENT) // → *GITHUB_EVENT
err := json.Unmarshal([]byte(eventDataRAW), eventDataJSON)
if err != nil {
    log.Fatal(err)
}
fmt.Println((*eventDataJSON)[0].Id) // ✅ 必须加 * 解引用

⚠️ 注意事项:

  • new(T) 总是返回 *T 且将内存置零,对切片类型而言,结果是 *[]struct{}(即 nil 指针),而 json.Unmarshal 能向 nil 切片指针写入数据,但后续访问需显式解引用;
  • make(T, n) 仅适用于 slice/map/channel,它分配并初始化底层数据结构,返回的是 T 类型值(非指针),语义更清晰、代码更健壮;
  • 实际项目中建议配合错误处理与空切片校验(如 len(eventDataJSON) > 0),防止 panic;
  • 结构体字段首字母必须大写(导出)才能被 json 包访问,示例中已满足该要求。

综上,优先采用 var eventDataJSON GITHUB_EVENT 方式——它语义明确、无需手动初始化、符合 Go 的惯用法,同时保证 eventDataJSON 是可直接索引的切片值,彻底规避指针索引陷阱。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

406

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

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

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

194

2025.06.09

golang结构体方法
golang结构体方法

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

186

2025.07.04

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

532

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

59

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

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

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