Skip to content

Latest commit

 

History

History
144 lines (105 loc) · 4.7 KB

README.md

File metadata and controls

144 lines (105 loc) · 4.7 KB

minimal-json

Build Status

A fast and minimal JSON parser and writer for Java. It's not an object mapper, but a bare-bones library that aims at being

  • minimal: only one package, fair amount of classes, no dependencies
  • fast: performance comparable or better than other state-of-the-art JSON parsers (see below)
  • leightweight: object representation with minimal memory footprint (e.g. no HashMaps involved)
  • easy to use: reading, writing and modifying JSON shouldn't require lots of code (short names, fluent style)

Minimal-json is fully covered by unit tests, and field-tested by the Eclipse RAP project.

Code Examples

Read JSON from a String or a Reader:

Reading is buffered already, so you don't need to wrap your reader in a BufferedReader.

JsonObject jsonObject = JsonObject.readFrom( string );
JsonArray jsonArray = JsonArray.readFrom( reader );

Access the contents of a JSON object:

String name = jsonObject.get( "name" ).asString();
int age = jsonObject.get( "age" ).asInt(); // asLong(), asFloat(), asDouble(), ...

// or iterate over the members:
for( Member member : jsonObject ) {
  String name = member.getName();
  JsonValue value = member.getValue();
  // ...
}

Access the contents of a JSON array:

String name = jsonArray.get( 0 ).asString();
int age = jsonArray.get( 1 ).asInt(); // asLong(), asFloat(), asDouble(), ...

// or iterate over the values:
for( JsonValue value : jsonArray ) {
  // ...
}

Access nested contents:

// Example: { "friends": [ { "name": "John", "age": 23 }, ... ], ... }
JsonArray friends = jsonObject.get( "friends" ).asArray();
String name = friends.get( 0 ).asObject().get( "name" ).asString();
int age = friends.get( 0 ).asObject().get( "age" ).asInt();

Create JSON objects and arrays:

JsonObject jsonObject = new JsonObject().add( "name", "John" ).add( "age", 23 );
// -> { "name": "John", "age", 23 }

JsonArray jsonArray = new JsonArray().add( "John" ).add( 23 );
// -> [ "John", 23 ]

Modify JSON objects and arrays:

jsonObject.set( "age", 24 );
jsonArray.set( 1, 24 ); // access element by index

jsonObject.remove( "age" );
jsonArray.remove( 1 );

Write JSON to a Writer:

Writing is not buffered (to avoid buffering twice), so you should use a BufferedWriter.

jsonObject.writeTo( writer );
jsonArray.writeTo( writer );

Export JSON as a String:

jsonObject.toString();
jsonArray.toString();

Concurrency

The JSON structures in this library (JsonObject and JsonArray) are not thread-safe. When instances of these classes must be accessed from multiple threads, while at least one of these threads modifies the contents, the application must ensure that all access to the instance is properly synchronized.

Iterators will throw a ConcurrentModificationException when the contents of a JSON structure have been modified after the creation of the iterator.

Performance

Below is the result of a performance comparison with other parsers, namely org.json, Gson, Jackson, and JSON.simple. In this benchmark, an example JSON text (~30kB) is parsed into a Java object and then serialized to JSON again. All benchmarks can be found in com.eclipsesource.json.performancetest.

Although minimal-json cannot outperform Jackson's exceptional writing performance (which is, to my knowledge, mostly achieved by caching), it offers a very good reading and writing performance.

Read/Write performance compared to other parsers

Disclaimer: This benchmark is restricted to a single use case and to my limited knowledge on the other libraries. It probably ignores better ways to use these libraries. The purpose of this benchmark is only to ensure a reasonable reading and writing performance compared to other state-of-the-art parsers.

Build

To build minimal-json on your machine, simply checkout the repository, cd into it and call maven:

cd minimal-json
mvn clean install

A continuous integration build is running at Travis-CI.

License

The code is available under the terms of the Eclipse Public License.