Skip to content
Paul Crovella edited this page Sep 17, 2016 · 9 revisions

JsonReader

When dealing with documents large enough that memory becomes an issue that you'll want a streaming parser - either a pull parser such as this, or a SAX-style push parser. For an overview of the differences between push and pull parsers see XML reader models: SAX versus XML pull parser - the article focuses on XML but the same concepts apply.

Another case for streaming parsers is if you've got some unusual JSON that includes duplicate names on an object's properties. This is allowed by the JSON specification, but json_decode() (and the majority of other implementations) will clobber properties as their keys collide. Streaming parsers allow you to access an element at a time and retrieve data that might otherwise disappear.

In keeping with better handling for edge cases, numbers from JSON will be returned as strings rather than automatically cast to integers or floats. This is to allow for more precise handling via BC Math or GMP should the need arise.

Clone this wiki locally