Note: Don’t forget to check out Benchmarks page to see the latest round up of binary and JSON serializers.
Follow on from my previous test which showed that the ServiceStack.Text JSON serializer was the top dog in town, I came across a little library called fastJson on codeplex so naturally I had to test it out and see how it compares to the rest!
So using my SimpleSpeedTester and repeating the same test as before I got the following results:
And graphically, this is how they look:
fastJson was the fastest in serialization and ServiceStack.Text was fastest in deserialization but there is very little separating the two libraries in both cases. Given a different data structure to serialize/deserialize you might end up with slightly different results but at the end of the day the two serializers have similar performance characteristics and both are some way ahead of the other JSON serializers I’ve tested.
Following on from request by @ICooper, I’ve included JayRock in the mix. However, as I had trouble deserializing (serializing was fine) the List<int> with JayRock I modified the test object slightly:
Otherwise, the conditions of the test are as before, and the results are as follows:
ServiceStack and fastJson still offer by far the best performance, especially with deserialization, but this time around ServiceStack proved to be the slight better of the two, why that’s the case with an int instead of a List<int> is beyond me though!
Again, if you’re interested in seeing the test code yourself, you can browse it here on Codeplex.
I’m an AWS Serverless Hero and the author of Production-Ready Serverless. I have run production workload at scale in AWS for nearly 10 years and I have been an architect or principal engineer with a variety of industries ranging from banking, e-commerce, sports streaming to mobile gaming. I currently work as an independent consultant focused on AWS and serverless.
Here is a complete list of all my posts on serverless and AWS Lambda. In the meantime, here are a few of my most popular blog posts.
- Lambda optimization tip – enable HTTP keep-alive
- You are thinking about serverless costs all wrong
- Many faced threats to Serverless security
- We can do better than percentile latencies
- I’m afraid you’re thinking about AWS Lambda cold starts all wrong
- Yubl’s road to Serverless
- AWS Lambda – should you have few monolithic functions or many single-purposed functions?
- AWS Lambda – compare coldstart time with different languages, memory and code sizes
- Guys, we’re doing pagination wrong