| commit | 03217c3e97663914aec3faafde50d081f197a0a2 | [log] [tgz] |
|---|---|---|
| author | Tao Wen <taowen@gmail.com> | Sat Oct 12 13:07:04 2019 |
| committer | GitHub <noreply@github.com> | Sat Oct 12 13:07:04 2019 |
| tree | 39fc05e74bb1ee717a9e683bce41b2b85eb33854 | |
| parent | 908eaed15109117a8551fb1d77e67a0a17e32ff9 [diff] | |
| parent | eec24895fec72d0e08d113f64421d1ab22e0fa27 [diff] |
Merge pull request #410 from liggitt/stack Limit nesting depth
A high-performance 100% compatible drop-in replacement of “encoding/json”
You can also use thrift like JSON using thrift-iterator

Raw Result (easyjson requires static code generation)
| ns/op | allocation bytes | allocation times | |
|---|---|---|---|
| std decode | 35510 ns/op | 1960 B/op | 99 allocs/op |
| easyjson decode | 8499 ns/op | 160 B/op | 4 allocs/op |
| jsoniter decode | 5623 ns/op | 160 B/op | 3 allocs/op |
| std encode | 2213 ns/op | 712 B/op | 5 allocs/op |
| easyjson encode | 883 ns/op | 576 B/op | 3 allocs/op |
| jsoniter encode | 837 ns/op | 384 B/op | 4 allocs/op |
Always benchmark with your own workload. The result depends heavily on the data input.
100% compatibility with standard lib
Replace
import "encoding/json"
json.Marshal(&data)
with
import "github.com/json-iterator/go"
var json = jsoniter.ConfigCompatibleWithStandardLibrary
json.Marshal(&data)
Replace
import "encoding/json"
json.Unmarshal(input, &data)
with
import "github.com/json-iterator/go"
var json = jsoniter.ConfigCompatibleWithStandardLibrary
json.Unmarshal(input, &data)
go get github.com/json-iterator/go
Contributors
Report issue or pull request, or email taowen@gmail.com, or 