[Python-Dev] Status of json (simplejson) in cpython
Antoine Pitrou
solipsis at pitrou.net
Sat Apr 16 01:12:29 CEST 2011
On Fri, 15 Apr 2011 14:27:04 -0700
Bob Ippolito <bob at redivi.com> wrote:
> On Fri, Apr 15, 2011 at 2:20 PM, Antoine Pitrou <solipsis at pitrou.net> wrote:
> > Le vendredi 15 avril 2011 à 14:18 -0700, Bob Ippolito a écrit :
> >> On Friday, April 15, 2011, Antoine Pitrou <solipsis at pitrou.net> wrote:
> >> >>
> >> >> > Since the JSON spec is set in stone, the changes
> >> >> > will mostly be about API (indentation, object conversion, etc)
> >> >> > and optimization. I presume the core parsing logic won't
> >> >> > be changing much.
> >> >>
> >> >> Actually the core parsing logic is very different (and MUCH faster),
> >> >
> >> > Are you talking about the Python logic or the C logic?
> >>
> >> Both, actually. IIRC simplejson in pure python typically beats json
> >> with it's C extension.
> >
> > Really? It would be nice to see some concrete benchmarks against both
> > repo tips.
>
> Maybe in a few weeks or months when I have time to finish up the
> benchmarks that I was working on... but it should be pretty easy for
> anyone to show that the version in CPython is very slow (and uses a
> lot more memory) in comparison to simplejson.
Well, here's a crude microbenchmark. I'm comparing 2.6+simplejson 2.1.3
to 3.3+json, so I'm avoiding integers:
* json.dumps:
$ python -m timeit -s "from simplejson import dumps, loads; \
d = dict((str(i), str(i)) for i in range(1000))" \
"dumps(d)"
- 2.6+simplejson: 372 usec per loop
- 3.2+json: 352 usec per loop
* json.loads:
$ python -m timeit -s "from simplejson import dumps, loads; \
d = dict((str(i), str(i)) for i in range(1000)); s = dumps(d)" \
"loads(s)"
- 2.6+simplejson: 224 usec per loop
- 3.2+json: 233 usec per loop
The runtimes look quite similar.
Antoine.
More information about the Python-Dev
mailing list