mirror of
https://github.com/json-iterator/go.git
synced 2025-06-06 22:36:25 +02:00
support cb
This commit is contained in:
parent
c5576a8a31
commit
e5e9a13f2e
44
jsoniter.go
44
jsoniter.go
@ -538,7 +538,7 @@ func (iter *Iterator) ReadArrayCB(cb func()) {
|
|||||||
return // null
|
return // null
|
||||||
}
|
}
|
||||||
if c != '[' {
|
if c != '[' {
|
||||||
iter.ReportError("ReadArray", "expect [ or n")
|
iter.ReportError("ReadArrayCB", "expect [ or n")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c = iter.nextToken()
|
c = iter.nextToken()
|
||||||
@ -557,13 +557,47 @@ func (iter *Iterator) ReadArrayCB(cb func()) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
if c != ',' {
|
if c != ',' {
|
||||||
iter.ReportError("ReadArray", "expect , or ]")
|
iter.ReportError("ReadArrayCB", "expect , or ]")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
iter.skipWhitespaces()
|
iter.skipWhitespaces()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (iter *Iterator) ReadObjectCB(cb func(string)) {
|
||||||
|
c := iter.nextToken()
|
||||||
|
if c == 'n' {
|
||||||
|
iter.skipNull()
|
||||||
|
return // null
|
||||||
|
}
|
||||||
|
if c != '{' {
|
||||||
|
iter.ReportError("ReadObjectCB", "expect { or n")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
c = iter.nextToken()
|
||||||
|
if c == '}' {
|
||||||
|
return // []
|
||||||
|
} else {
|
||||||
|
iter.unreadByte()
|
||||||
|
}
|
||||||
|
for {
|
||||||
|
iter.skipWhitespaces()
|
||||||
|
field := iter.readObjectField()
|
||||||
|
if iter.Error != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
cb(field)
|
||||||
|
c = iter.nextToken()
|
||||||
|
if c == '}' {
|
||||||
|
return // end of object
|
||||||
|
}
|
||||||
|
if c != ',' {
|
||||||
|
iter.ReportError("ReadObjectCB", `expect ,`)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (iter *Iterator) ReadObject() (ret string) {
|
func (iter *Iterator) ReadObject() (ret string) {
|
||||||
c := iter.nextToken()
|
c := iter.nextToken()
|
||||||
if iter.Error != nil {
|
if iter.Error != nil {
|
||||||
@ -607,13 +641,7 @@ func (iter *Iterator) ReadObject() (ret string) {
|
|||||||
func (iter *Iterator) readObjectField() (ret string) {
|
func (iter *Iterator) readObjectField() (ret string) {
|
||||||
str := iter.ReadStringAsBytes()
|
str := iter.ReadStringAsBytes()
|
||||||
field := *(*string)(unsafe.Pointer(&str))
|
field := *(*string)(unsafe.Pointer(&str))
|
||||||
if iter.Error != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
c := iter.nextToken()
|
c := iter.nextToken()
|
||||||
if iter.Error != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if c != ':' {
|
if c != ':' {
|
||||||
iter.ReportError("ReadObject", "expect : after object field")
|
iter.ReportError("ReadObject", "expect : after object field")
|
||||||
return
|
return
|
||||||
|
@ -66,6 +66,18 @@ func Test_two_field(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Test_cb(t *testing.T) {
|
||||||
|
iter := ParseString(`{ "a": "b" , "c": "d" }`)
|
||||||
|
count := 0
|
||||||
|
iter.ReadObjectCB(func(field string) {
|
||||||
|
iter.Skip()
|
||||||
|
count += 1
|
||||||
|
})
|
||||||
|
if count != 2 {
|
||||||
|
t.Fatal(count)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
type TestObj struct {
|
type TestObj struct {
|
||||||
Field1 string
|
Field1 string
|
||||||
Field2 uint64
|
Field2 uint64
|
||||||
@ -88,6 +100,23 @@ for field := iter.ReadObject(); field != ""; field = iter.ReadObject() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Benchmark_jsoniter_cb(b *testing.B) {
|
||||||
|
for n := 0; n < b.N; n++ {
|
||||||
|
iter := ParseString(`{"field1": "1", "field2": 2}`)
|
||||||
|
obj := TestObj{}
|
||||||
|
iter.ReadObjectCB(func(field string) {
|
||||||
|
switch field {
|
||||||
|
case "field1":
|
||||||
|
obj.Field1 = iter.ReadString()
|
||||||
|
case "field2":
|
||||||
|
obj.Field2 = iter.ReadUint64()
|
||||||
|
default:
|
||||||
|
iter.ReportError("bind object", "unexpected field")
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func Benchmark_json_object(b *testing.B) {
|
func Benchmark_json_object(b *testing.B) {
|
||||||
for n := 0; n < b.N; n++ {
|
for n := 0; n < b.N; n++ {
|
||||||
result := TestObj{}
|
result := TestObj{}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user