jsoniter可零改动提速2–5倍,easyjson生成代码消除反射提升3–8倍,json.RawMessage延迟解析避免冗余,固定结构体替代interface{}降低开销。
Go 标准库的 encoding/json 默认足够可靠,但不是最快的;如果你的接口 30% 时间花在 jso 上,说明它已成瓶颈,该换方案了。
jsoniter 替代标准库,零代码改动即可提速 2–5 倍多数场景下,jsoniter 是最省心的加速方案:API 完全兼容 encoding/json,只需替换 import 路径,无需改结构体或调用逻辑。
go get github.com/json-iterator/go
import json "github.com/json-iterator/go"(而非 "encoding/json")json.Unmarshal 和 json.Marshal,行为一致,但底层用了更激进的 unsafe 和预编译反射缓存json.RawMessage 或自定义 UnmarshalJSON 方法,需验证兼容性;jsoniter 对某些边缘 case(如嵌套过深的 interface{})默认行为略有不同easyjson 消除反射开销当单次请求需解析成百上千个相同结构体(如日志批量上报、ETL 流水线),反射是最大拖累;easyjson 把 Unmarshal 编译成纯函数调用,完全绕过 reflect。
easyjson -all user.go,会生成 user_easyjson.go
User.UnmarshalJSON(data),而非 json.Unmarshal(data, &u)
interface{}、动态 key 等运行时特性json.RawMessage 延迟解析常见模式是先解出顶层字段做路由判断(如 "type": "order"),再按类型解析子结构;若每次都全量解析,浪费严重。
json.RawMessage 类型,只在真正需要时才调用 json.Unmarshal
type Event struct {
Type string `json:"type"`
Data json.RawMessage `json:"data"`
}
// 后续按 Type 分支解析 Data,避免无谓解析json.RawMessage 本质是 []byte 切片,不拷贝原始数据,因此必须确保源 []byte 生命周期覆盖整个使用过程,否则可能引发 panic 或读到脏数据interface{} 和 map[string]interface{} 的隐式开销这类泛型解析看似灵活,实则强制走最慢路径:每个字段都要动态推导类型、分配内存、构建嵌套 map/slice,GC 压力也显著上升。
map[string]interface{},至少预估 key 集合并用 make(map[string]interface{}, N) 初始化容量,减少扩容次数jsoniter.ConfigCompatibleWithStandardLibrary 下的 interface{} 解析比标准库略快,但仍是性能黑洞,别把它当默认选项真正影响 JSON 解析速度的,往往不是算法本身,而是你是否让 Go 知道“这个结构永远长这样”——越早放弃通用性,越容易拿到确定性性能。生成代码、延迟解析、固定类型,三者选其二,通常就能砍掉 70% 的解析耗时。