mirror of
https://github.com/json-iterator/go.git
synced 2024-11-24 08:22:14 +02:00
A high-performance 100% compatible drop-in replacement of "encoding/json"
http://jsoniter.com/migrate-from-go-std.html
assert | ||
require | ||
feature_adapter.go | ||
feature_any_array.go | ||
feature_any_bool.go | ||
feature_any_float.go | ||
feature_any_int.go | ||
feature_any_invalid.go | ||
feature_any_nil.go | ||
feature_any_object.go | ||
feature_any_string.go | ||
feature_any.go | ||
feature_iter_array.go | ||
feature_iter_float.go | ||
feature_iter_int.go | ||
feature_iter_object.go | ||
feature_iter_skip.go | ||
feature_iter_string.go | ||
feature_iter.go | ||
feature_reflect_array.go | ||
feature_reflect_native.go | ||
feature_reflect_object.go | ||
feature_reflect.go | ||
feature_stream_float.go | ||
feature_stream_int.go | ||
feature_stream.go | ||
jsoniter_array_test.go | ||
jsoniter_base64_test.go | ||
jsoniter_bool_test.go | ||
jsoniter_customize_test.go | ||
jsoniter_demo_test.go | ||
jsoniter_find_end_test.go | ||
jsoniter_float_test.go | ||
jsoniter_int_test.go | ||
jsoniter_interface_test.go | ||
jsoniter_io_test.go | ||
jsoniter_large_file_test.go | ||
jsoniter_map_test.go | ||
jsoniter_nested_test.go | ||
jsoniter_null_test.go | ||
jsoniter_object_test.go | ||
jsoniter_optional_test.go | ||
jsoniter_reflect_native_test.go | ||
jsoniter_reflect_struct_test.go | ||
jsoniter_reflect_test.go | ||
jsoniter_skip_test.go | ||
jsoniter_string_test.go | ||
LICENSE | ||
README.md |
jsoniter (json-iterator) is fast and flexible JSON parser available in Java and Go
Why jsoniter?
- Jsoniter is the fastest JSON parser. It could be up to 10x faster than normal parser, data binding included. Shameless self benchmark
- Extremely flexible api. You can mix and match three different styles: bind-api, any-api or iterator-api. Checkout your api choices
- Unique iterator api can iterate through JSON directly, zero memory allocation! See how iterator works
Show off
Here is a quick show off, for more complete report you can checkout the full benchmark with in-depth optimization to back the numbers up
Bind-API is the best
Bind-api should always be the first choice. Given this JSON document [0,1,2,3]
Parse with Go bind-api
import "github.com/json-iterator/go"
iter := jsoniter.ParseString(`[0,1,2,3]`)
val := []int{}
iter.Read(&val)
fmt.Println(val[3])
Iterator-API for quick extraction
When you do not need to get all the data back, just extract some.
Parse with Go iterator-api
import "github.com/json-iterator/go"
iter := ParseString(`[0, [1, 2], [3, 4], 5]`)
count := 0
for iter.ReadArray() {
iter.Skip()
count++
}
fmt.Println(count) // 4
Any-API for maximum flexibility
Parse with Go any-api
import "github.com/json-iterator/go"
iter := jsoniter.ParseString(`[{"field1":"11","field2":"12"},{"field1":"21","field2":"22"}]`)
val := iter.ReadAny()
fmt.Println(val.ToInt(1, "field2")) // 22
Notice you can extract from nested data structure, and convert any type to the type to you want.
How to get
go get github.com/json-iterator/go
Contribution Welcomed !
Report issue or pull request, or email taowen@gmail.com, or