feature_reflect.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530
  1. package jsoniter
  2. import (
  3. "fmt"
  4. "reflect"
  5. "sync/atomic"
  6. "unsafe"
  7. "encoding/json"
  8. "encoding"
  9. )
  10. /*
  11. Reflection on type to create decoders, which is then cached
  12. Reflection on value is avoided as we can, as the reflect.Value itself will allocate, with following exceptions
  13. 1. create instance of new value, for example *int will need a int to be allocated
  14. 2. append to slice, if the existing cap is not enough, allocate will be done using Reflect.New
  15. 3. assignment to map, both key and value will be reflect.Value
  16. For a simple struct binding, it will be reflect.Value free and allocation free
  17. */
  18. type Decoder interface {
  19. decode(ptr unsafe.Pointer, iter *Iterator)
  20. }
  21. type Encoder interface {
  22. isEmpty(ptr unsafe.Pointer) bool
  23. encode(ptr unsafe.Pointer, stream *Stream)
  24. encodeInterface(val interface{}, stream *Stream)
  25. }
  26. func writeToStream(val interface{}, stream *Stream, encoder Encoder) {
  27. e := (*emptyInterface)(unsafe.Pointer(&val))
  28. if reflect.TypeOf(val).Kind() == reflect.Ptr {
  29. encoder.encode(unsafe.Pointer(&e.word), stream)
  30. } else {
  31. encoder.encode(e.word, stream)
  32. }
  33. }
  34. type DecoderFunc func(ptr unsafe.Pointer, iter *Iterator)
  35. type EncoderFunc func(ptr unsafe.Pointer, stream *Stream)
  36. type ExtensionFunc func(typ reflect.Type, field *reflect.StructField) ([]string, EncoderFunc, DecoderFunc)
  37. type funcDecoder struct {
  38. fun DecoderFunc
  39. }
  40. func (decoder *funcDecoder) decode(ptr unsafe.Pointer, iter *Iterator) {
  41. decoder.fun(ptr, iter)
  42. }
  43. type funcEncoder struct {
  44. fun EncoderFunc
  45. }
  46. func (encoder *funcEncoder) encode(ptr unsafe.Pointer, stream *Stream) {
  47. encoder.fun(ptr, stream)
  48. }
  49. func (encoder *funcEncoder) encodeInterface(val interface{}, stream *Stream) {
  50. writeToStream(val, stream, encoder)
  51. }
  52. func (encoder *funcEncoder) isEmpty(ptr unsafe.Pointer) bool {
  53. return false
  54. }
  55. var DECODERS unsafe.Pointer
  56. var ENCODERS unsafe.Pointer
  57. var typeDecoders map[string]Decoder
  58. var fieldDecoders map[string]Decoder
  59. var typeEncoders map[string]Encoder
  60. var fieldEncoders map[string]Encoder
  61. var extensions []ExtensionFunc
  62. var jsonNumberType reflect.Type
  63. var jsonRawMessageType reflect.Type
  64. var anyType reflect.Type
  65. var marshalerType reflect.Type
  66. var unmarshalerType reflect.Type
  67. var textUnmarshalerType reflect.Type
  68. func init() {
  69. typeDecoders = map[string]Decoder{}
  70. fieldDecoders = map[string]Decoder{}
  71. typeEncoders = map[string]Encoder{}
  72. fieldEncoders = map[string]Encoder{}
  73. extensions = []ExtensionFunc{}
  74. atomic.StorePointer(&DECODERS, unsafe.Pointer(&map[string]Decoder{}))
  75. atomic.StorePointer(&ENCODERS, unsafe.Pointer(&map[string]Encoder{}))
  76. jsonNumberType = reflect.TypeOf((*json.Number)(nil)).Elem()
  77. jsonRawMessageType = reflect.TypeOf((*json.RawMessage)(nil)).Elem()
  78. anyType = reflect.TypeOf((*Any)(nil)).Elem()
  79. marshalerType = reflect.TypeOf((*json.Marshaler)(nil)).Elem()
  80. unmarshalerType = reflect.TypeOf((*json.Unmarshaler)(nil)).Elem()
  81. textUnmarshalerType = reflect.TypeOf((*encoding.TextUnmarshaler)(nil)).Elem()
  82. }
  83. func addDecoderToCache(cacheKey reflect.Type, decoder Decoder) {
  84. done := false
  85. for !done {
  86. ptr := atomic.LoadPointer(&DECODERS)
  87. cache := *(*map[reflect.Type]Decoder)(ptr)
  88. copied := map[reflect.Type]Decoder{}
  89. for k, v := range cache {
  90. copied[k] = v
  91. }
  92. copied[cacheKey] = decoder
  93. done = atomic.CompareAndSwapPointer(&DECODERS, ptr, unsafe.Pointer(&copied))
  94. }
  95. }
  96. func addEncoderToCache(cacheKey reflect.Type, encoder Encoder) {
  97. done := false
  98. for !done {
  99. ptr := atomic.LoadPointer(&ENCODERS)
  100. cache := *(*map[reflect.Type]Encoder)(ptr)
  101. copied := map[reflect.Type]Encoder{}
  102. for k, v := range cache {
  103. copied[k] = v
  104. }
  105. copied[cacheKey] = encoder
  106. done = atomic.CompareAndSwapPointer(&ENCODERS, ptr, unsafe.Pointer(&copied))
  107. }
  108. }
  109. func getDecoderFromCache(cacheKey reflect.Type) Decoder {
  110. ptr := atomic.LoadPointer(&DECODERS)
  111. cache := *(*map[reflect.Type]Decoder)(ptr)
  112. return cache[cacheKey]
  113. }
  114. func getEncoderFromCache(cacheKey reflect.Type) Encoder {
  115. ptr := atomic.LoadPointer(&ENCODERS)
  116. cache := *(*map[reflect.Type]Encoder)(ptr)
  117. return cache[cacheKey]
  118. }
  119. // RegisterTypeDecoder can register a type for json object
  120. func RegisterTypeDecoder(typ string, fun DecoderFunc) {
  121. typeDecoders[typ] = &funcDecoder{fun}
  122. }
  123. // RegisterFieldDecoder can register a type for json field
  124. func RegisterFieldDecoder(typ string, field string, fun DecoderFunc) {
  125. fieldDecoders[fmt.Sprintf("%s/%s", typ, field)] = &funcDecoder{fun}
  126. }
  127. func RegisterTypeEncoder(typ string, fun EncoderFunc) {
  128. typeEncoders[typ] = &funcEncoder{fun}
  129. }
  130. func RegisterFieldEncoder(typ string, field string, fun EncoderFunc) {
  131. fieldEncoders[fmt.Sprintf("%s/%s", typ, field)] = &funcEncoder{fun}
  132. }
  133. // RegisterExtension can register a custom extension
  134. func RegisterExtension(extension ExtensionFunc) {
  135. extensions = append(extensions, extension)
  136. }
  137. // CleanDecoders cleans decoders registered
  138. func CleanDecoders() {
  139. typeDecoders = map[string]Decoder{}
  140. fieldDecoders = map[string]Decoder{}
  141. }
  142. func CleanEncoders() {
  143. typeEncoders = map[string]Encoder{}
  144. fieldEncoders = map[string]Encoder{}
  145. }
  146. type optionalDecoder struct {
  147. valueType reflect.Type
  148. valueDecoder Decoder
  149. }
  150. func (decoder *optionalDecoder) decode(ptr unsafe.Pointer, iter *Iterator) {
  151. if iter.ReadNil() {
  152. *((*unsafe.Pointer)(ptr)) = nil
  153. } else {
  154. if *((*unsafe.Pointer)(ptr)) == nil {
  155. // pointer to null, we have to allocate memory to hold the value
  156. value := reflect.New(decoder.valueType)
  157. decoder.valueDecoder.decode(unsafe.Pointer(value.Pointer()), iter)
  158. *((*uintptr)(ptr)) = value.Pointer()
  159. } else {
  160. // reuse existing instance
  161. decoder.valueDecoder.decode(*((*unsafe.Pointer)(ptr)), iter)
  162. }
  163. }
  164. }
  165. type optionalEncoder struct {
  166. valueEncoder Encoder
  167. }
  168. func (encoder *optionalEncoder) encode(ptr unsafe.Pointer, stream *Stream) {
  169. if *((*unsafe.Pointer)(ptr)) == nil {
  170. stream.WriteNil()
  171. } else {
  172. encoder.valueEncoder.encode(*((*unsafe.Pointer)(ptr)), stream)
  173. }
  174. }
  175. func (encoder *optionalEncoder) encodeInterface(val interface{}, stream *Stream) {
  176. writeToStream(val, stream, encoder)
  177. }
  178. func (encoder *optionalEncoder) isEmpty(ptr unsafe.Pointer) bool {
  179. if *((*unsafe.Pointer)(ptr)) == nil {
  180. return true
  181. } else {
  182. return encoder.valueEncoder.isEmpty(*((*unsafe.Pointer)(ptr)))
  183. }
  184. }
  185. type placeholderEncoder struct {
  186. valueEncoder Encoder
  187. }
  188. func (encoder *placeholderEncoder) encode(ptr unsafe.Pointer, stream *Stream) {
  189. encoder.valueEncoder.encode(ptr, stream)
  190. }
  191. func (encoder *placeholderEncoder) encodeInterface(val interface{}, stream *Stream) {
  192. writeToStream(val, stream, encoder)
  193. }
  194. func (encoder *placeholderEncoder) isEmpty(ptr unsafe.Pointer) bool {
  195. return encoder.valueEncoder.isEmpty(ptr)
  196. }
  197. type placeholderDecoder struct {
  198. valueDecoder Decoder
  199. }
  200. func (decoder *placeholderDecoder) decode(ptr unsafe.Pointer, iter *Iterator) {
  201. decoder.valueDecoder.decode(ptr, iter)
  202. }
  203. // emptyInterface is the header for an interface{} value.
  204. type emptyInterface struct {
  205. typ unsafe.Pointer
  206. word unsafe.Pointer
  207. }
  208. // emptyInterface is the header for an interface with method (not interface{})
  209. type nonEmptyInterface struct {
  210. // see ../runtime/iface.go:/Itab
  211. itab *struct {
  212. ityp unsafe.Pointer // static interface type
  213. typ unsafe.Pointer // dynamic concrete type
  214. link unsafe.Pointer
  215. bad int32
  216. unused int32
  217. fun [100000]unsafe.Pointer // method table
  218. }
  219. word unsafe.Pointer
  220. }
  221. // Read converts an Iterator instance into go interface, same as json.Unmarshal
  222. func (iter *Iterator) ReadVal(obj interface{}) {
  223. typ := reflect.TypeOf(obj)
  224. cacheKey := typ.Elem()
  225. cachedDecoder := getDecoderFromCache(cacheKey)
  226. if cachedDecoder == nil {
  227. decoder, err := decoderOfType(cacheKey)
  228. if err != nil {
  229. iter.Error = err
  230. return
  231. }
  232. cachedDecoder = decoder
  233. addDecoderToCache(cacheKey, decoder)
  234. }
  235. e := (*emptyInterface)(unsafe.Pointer(&obj))
  236. cachedDecoder.decode(e.word, iter)
  237. }
  238. func (stream *Stream) WriteVal(val interface{}) {
  239. if nil == val {
  240. stream.WriteNil()
  241. return
  242. }
  243. typ := reflect.TypeOf(val)
  244. cacheKey := typ
  245. cachedEncoder := getEncoderFromCache(cacheKey)
  246. if cachedEncoder == nil {
  247. encoder, err := encoderOfType(cacheKey)
  248. if err != nil {
  249. stream.Error = err
  250. return
  251. }
  252. cachedEncoder = encoder
  253. addEncoderToCache(cacheKey, encoder)
  254. }
  255. cachedEncoder.encodeInterface(val, stream)
  256. }
  257. type prefix string
  258. func (p prefix) addToDecoder(decoder Decoder, err error) (Decoder, error) {
  259. if err != nil {
  260. return nil, fmt.Errorf("%s: %s", p, err.Error())
  261. }
  262. return decoder, err
  263. }
  264. func (p prefix) addToEncoder(encoder Encoder, err error) (Encoder, error) {
  265. if err != nil {
  266. return nil, fmt.Errorf("%s: %s", p, err.Error())
  267. }
  268. return encoder, err
  269. }
  270. func decoderOfType(typ reflect.Type) (Decoder, error) {
  271. typeName := typ.String()
  272. typeDecoder := typeDecoders[typeName]
  273. if typeDecoder != nil {
  274. return typeDecoder, nil
  275. }
  276. if typ.Kind() == reflect.Ptr {
  277. typeDecoder := typeDecoders[typ.Elem().String()]
  278. if typeDecoder != nil {
  279. return &optionalDecoder{typ.Elem(), typeDecoder}, nil
  280. }
  281. }
  282. cacheKey := typ
  283. cachedDecoder := getDecoderFromCache(cacheKey)
  284. if cachedDecoder != nil {
  285. return cachedDecoder, nil
  286. }
  287. placeholder := &placeholderDecoder{}
  288. addDecoderToCache(cacheKey, placeholder)
  289. newDecoder, err := createDecoderOfType(typ)
  290. placeholder.valueDecoder = newDecoder
  291. addDecoderToCache(cacheKey, newDecoder)
  292. return newDecoder, err
  293. }
  294. func createDecoderOfType(typ reflect.Type) (Decoder, error) {
  295. if typ.AssignableTo(jsonRawMessageType) {
  296. return &jsonRawMessageCodec{}, nil
  297. }
  298. if typ.AssignableTo(jsonNumberType) {
  299. return &jsonNumberCodec{}, nil
  300. }
  301. if typ.ConvertibleTo(unmarshalerType) {
  302. templateInterface := reflect.New(typ).Elem().Interface()
  303. return &optionalDecoder{typ, &unmarshalerDecoder{extractInterface(templateInterface)}}, nil
  304. }
  305. if typ.ConvertibleTo(anyType) {
  306. return &anyCodec{}, nil
  307. }
  308. switch typ.Kind() {
  309. case reflect.String:
  310. return &stringCodec{}, nil
  311. case reflect.Int:
  312. return &intCodec{}, nil
  313. case reflect.Int8:
  314. return &int8Codec{}, nil
  315. case reflect.Int16:
  316. return &int16Codec{}, nil
  317. case reflect.Int32:
  318. return &int32Codec{}, nil
  319. case reflect.Int64:
  320. return &int64Codec{}, nil
  321. case reflect.Uint:
  322. return &uintCodec{}, nil
  323. case reflect.Uint8:
  324. return &uint8Codec{}, nil
  325. case reflect.Uint16:
  326. return &uint16Codec{}, nil
  327. case reflect.Uint32:
  328. return &uint32Codec{}, nil
  329. case reflect.Uint64:
  330. return &uint64Codec{}, nil
  331. case reflect.Float32:
  332. return &float32Codec{}, nil
  333. case reflect.Float64:
  334. return &float64Codec{}, nil
  335. case reflect.Bool:
  336. return &boolCodec{}, nil
  337. case reflect.Interface:
  338. if typ.NumMethod() == 0 {
  339. return &emptyInterfaceCodec{}, nil
  340. } else {
  341. return &nonEmptyInterfaceCodec{}, nil
  342. }
  343. case reflect.Struct:
  344. return prefix(fmt.Sprintf("[%s]", typ.String())).addToDecoder(decoderOfStruct(typ))
  345. case reflect.Slice:
  346. return prefix("[slice]").addToDecoder(decoderOfSlice(typ))
  347. case reflect.Map:
  348. return prefix("[map]").addToDecoder(decoderOfMap(typ))
  349. case reflect.Ptr:
  350. return prefix("[optional]").addToDecoder(decoderOfOptional(typ))
  351. default:
  352. return nil, fmt.Errorf("unsupported type: %v", typ)
  353. }
  354. }
  355. func encoderOfType(typ reflect.Type) (Encoder, error) {
  356. typeName := typ.String()
  357. typeEncoder := typeEncoders[typeName]
  358. if typeEncoder != nil {
  359. return typeEncoder, nil
  360. }
  361. if typ.Kind() == reflect.Ptr {
  362. typeEncoder := typeEncoders[typ.Elem().String()]
  363. if typeEncoder != nil {
  364. return &optionalEncoder{typeEncoder}, nil
  365. }
  366. }
  367. cacheKey := typ
  368. cachedEncoder := getEncoderFromCache(cacheKey)
  369. if cachedEncoder != nil {
  370. return cachedEncoder, nil
  371. }
  372. placeholder := &placeholderEncoder{}
  373. addEncoderToCache(cacheKey, placeholder)
  374. newEncoder, err := createEncoderOfType(typ)
  375. placeholder.valueEncoder = newEncoder
  376. addEncoderToCache(cacheKey, newEncoder)
  377. return newEncoder, err
  378. }
  379. func createEncoderOfType(typ reflect.Type) (Encoder, error) {
  380. if typ.AssignableTo(jsonRawMessageType) {
  381. return &jsonRawMessageCodec{}, nil
  382. }
  383. if typ.AssignableTo(jsonNumberType) {
  384. return &jsonNumberCodec{}, nil
  385. }
  386. if typ.ConvertibleTo(marshalerType) {
  387. templateInterface := reflect.New(typ).Elem().Interface()
  388. return &marshalerEncoder{extractInterface(templateInterface)}, nil
  389. }
  390. if typ.ConvertibleTo(anyType) {
  391. return &anyCodec{}, nil
  392. }
  393. kind := typ.Kind()
  394. switch kind {
  395. case reflect.String:
  396. return &stringCodec{}, nil
  397. case reflect.Int:
  398. return &intCodec{}, nil
  399. case reflect.Int8:
  400. return &int8Codec{}, nil
  401. case reflect.Int16:
  402. return &int16Codec{}, nil
  403. case reflect.Int32:
  404. return &int32Codec{}, nil
  405. case reflect.Int64:
  406. return &int64Codec{}, nil
  407. case reflect.Uint:
  408. return &uintCodec{}, nil
  409. case reflect.Uint8:
  410. return &uint8Codec{}, nil
  411. case reflect.Uint16:
  412. return &uint16Codec{}, nil
  413. case reflect.Uint32:
  414. return &uint32Codec{}, nil
  415. case reflect.Uint64:
  416. return &uint64Codec{}, nil
  417. case reflect.Float32:
  418. return &float32Codec{}, nil
  419. case reflect.Float64:
  420. return &float64Codec{}, nil
  421. case reflect.Bool:
  422. return &boolCodec{}, nil
  423. case reflect.Interface:
  424. if typ.NumMethod() == 0 {
  425. return &emptyInterfaceCodec{}, nil
  426. } else {
  427. return &nonEmptyInterfaceCodec{}, nil
  428. }
  429. case reflect.Struct:
  430. return prefix(fmt.Sprintf("[%s]", typ.String())).addToEncoder(encoderOfStruct(typ))
  431. case reflect.Slice:
  432. return prefix("[slice]").addToEncoder(encoderOfSlice(typ))
  433. case reflect.Map:
  434. return prefix("[map]").addToEncoder(encoderOfMap(typ))
  435. case reflect.Ptr:
  436. return prefix("[optional]").addToEncoder(encoderOfOptional(typ))
  437. default:
  438. return nil, fmt.Errorf("unsupported type: %v", typ)
  439. }
  440. }
  441. func decoderOfOptional(typ reflect.Type) (Decoder, error) {
  442. elemType := typ.Elem()
  443. decoder, err := decoderOfType(elemType)
  444. if err != nil {
  445. return nil, err
  446. }
  447. return &optionalDecoder{elemType, decoder}, nil
  448. }
  449. func encoderOfOptional(typ reflect.Type) (Encoder, error) {
  450. elemType := typ.Elem()
  451. decoder, err := encoderOfType(elemType)
  452. if err != nil {
  453. return nil, err
  454. }
  455. return &optionalEncoder{decoder}, nil
  456. }
  457. func decoderOfMap(typ reflect.Type) (Decoder, error) {
  458. decoder, err := decoderOfType(typ.Elem())
  459. if err != nil {
  460. return nil, err
  461. }
  462. mapInterface := reflect.New(typ).Interface()
  463. return &mapDecoder{typ, typ.Key(), typ.Elem(), decoder, extractInterface(mapInterface)}, nil
  464. }
  465. func extractInterface(val interface{}) emptyInterface {
  466. return *((*emptyInterface)(unsafe.Pointer(&val)))
  467. }
  468. func encoderOfMap(typ reflect.Type) (Encoder, error) {
  469. elemType := typ.Elem()
  470. encoder, err := encoderOfType(elemType)
  471. if err != nil {
  472. return nil, err
  473. }
  474. mapInterface := reflect.New(typ).Elem().Interface()
  475. return &mapEncoder{typ, elemType, encoder, *((*emptyInterface)(unsafe.Pointer(&mapInterface)))}, nil
  476. }