sync.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // forked from github.com/creationix/jsonparse
  2. // brew install yajl
  3. // npm install jsonparse yajl
  4. // node bench/sync.js samples/npm.json 5
  5. // jsonfile number of cycles
  6. var fs = require('fs')
  7. , clarinet = require('../clarinet')
  8. , Parser = require('jsonparse')
  9. , jsonparser = new Parser()
  10. , file = fs.readFileSync(process.argv[2])
  11. , string = file.toString()
  12. , p = clarinet.parser()
  13. , s = clarinet.createStream()
  14. , max = process.argv[3] || 1
  15. , n = process.argv[4] || 9
  16. ;
  17. console.log('=N("node bench/sync.js ' + process.argv[2] + ' ' +
  18. max + ' ' + n + '")');
  19. console.log('=N("clp (clarinet parser), cls (clarinet event emitter)")');
  20. console.log('=N("jpp (creationix/jsonparse), v8s (JSON.parse string)")');
  21. console.log('=N("v8b (JSON.parse buffer)")');
  22. while (true) {
  23. try {
  24. start = Date.now();
  25. for (var i = 0; i < max; i++) p.write(string);
  26. console.log("clp, %s", Date.now()-start);
  27. } catch (ex1) { }
  28. // slower
  29. try {
  30. start = Date.now();
  31. for (var i = 0; i < max; i++) s.write(string);
  32. console.log("cls, %s", Date.now()-start);
  33. } catch (ex1) { }
  34. try {
  35. start = Date.now();
  36. for (var i = 0; i < max; i++) jsonparser.write(file);
  37. console.log("jpp, %s", Date.now()-start);
  38. } catch (ex2) { }
  39. try {
  40. start = Date.now();
  41. for (var i = 0; i < max; i++) JSON.parse(string);
  42. console.log("v8s, %s", Date.now()-start);
  43. } catch (ex3) { }
  44. // slower
  45. try {
  46. start = Date.now();
  47. for (var i = 0; i < max; i++) JSON.parse(file);
  48. console.log("v8b, %s", Date.now()-start);
  49. } catch (ex4) { }
  50. if(n===0) return;
  51. n--;
  52. }