Skip to content

Instantly share code, notes, and snippets.

@muga
Created June 18, 2017 10:18
Show Gist options
  • Save muga/e566299fc9afdaa0511a8bb7804d5a7f to your computer and use it in GitHub Desktop.
Save muga/e566299fc9afdaa0511a8bb7804d5a7f to your computer and use it in GitHub Desktop.
Implement key conversion with symbol in Java to reduce the count of objects passing between JRuby and Java
1,000 times Date._strptime('2001-02-03', '%Y-%m-%d')
user system total real
mri 2.4.1 0.000000 0.000000 0.070000 ( 0.086790)
jruby 9.1.9.0 0.000000 0.000000 8.020000 ( 3.789310)
jruby (master) 0.000000 0.000000 7.290000 ( 4.043696)
10,000 times Date._strptime('2001-02-03', '%Y-%m-%d')
user system total real
mri 2.4.1 0.000000 0.000000 0.090000 ( 0.142577)
jruby 9.1.9.0 0.000000 0.000000 12.450000 ( 7.671689)
jruby (master) 0.000000 0.000000 8.180000 ( 4.401070)
100,000 times Date._strptime('2001-02-03', '%Y-%m-%d')
user system total real
mri 2.4.1 0.000000 0.000000 0.200000 ( 0.209632)
jruby 9.1.9.0 0.000000 0.000000 17.420000 ( 10.452343)
jruby (master) 0.000000 0.000000 9.010000 ( 4.304226)
1,000,000 times Date._strptime('2001-02-03', '%Y-%m-%d')
user system total real
mri 2.4.1 0.000000 0.000000 1.260000 ( 1.362743)
jruby 9.1.9.0 0.000000 0.000000 60.650000 ( 59.166195)
jruby (master) 0.000000 0.000000 12.170000 ( 7.638632)
10,000,000 times Date._strptime('2001-02-03', '%Y-%m-%d')
user system total real
mri 2.4.1 0.000000 0.000000 11.970000 ( 12.952664)
jruby 9.1.9.0 0.000000 0.000000 482.880000 (516.068042)
jruby (master) 0.000000 0.000000 36.650000 ( 35.192336)
---
$ bench/run
======================environment======================
mri 2.4.1
command: ~/.rbenv/versions/2.4.1/bin/ruby
version: ruby 2.4.1p111 (2017-03-22 revision 58053) [x86_64-darwin16]
jruby 9.1.9.0
command: ~/.rbenv/versions/jruby-9.1.9.0/bin/ruby
version: jruby 9.1.9.0 (2.3.3) 2017-05-15 28aa830 Java HotSpot(TM) 64-Bit Server VM 25.131-b11 on 1.8.0_131-b11 +jit [darwin-x86_64]
jruby (master)
command: /Users/muga/works/sources/jruby-jruby/bin/ruby
version: jruby 9.1.11.0-SNAPSHOT (2.3.3) 2017-05-26 6684684 Java HotSpot(TM) 64-Bit Server VM 25.131-b11 on 1.8.0_131-b11 +jit [darwin-x86_64]
=============bench/strptime_Y-m-d_1000.rb==============
Rehearsal --------------------------------------------------
mri 2.4.1 0.000000 0.000000 0.090000 ( 0.187858)
jruby 9.1.9.0 0.000000 0.000000 8.240000 ( 4.576449)
jruby (master) 0.000000 0.000000 7.080000 ( 4.387552)
---------------------------------------- total: 15.410000sec
user system total real
mri 2.4.1 0.000000 0.000000 0.070000 ( 0.086790)
jruby 9.1.9.0 0.000000 0.000000 8.020000 ( 3.789310)
jruby (master) 0.000000 0.000000 7.290000 ( 4.043696)
=============bench/strptime_Y-m-d_10000.rb=============
Rehearsal --------------------------------------------------
mri 2.4.1 0.000000 0.000000 0.090000 ( 0.142087)
jruby 9.1.9.0 0.000000 0.000000 12.050000 ( 6.411059)
jruby (master) 0.000000 0.000000 7.990000 ( 4.985036)
---------------------------------------- total: 20.130000sec
user system total real
mri 2.4.1 0.000000 0.000000 0.090000 ( 0.142577)
jruby 9.1.9.0 0.000000 0.000000 12.450000 ( 7.671689)
jruby (master) 0.000000 0.000000 8.180000 ( 4.401070)
============bench/strptime_Y-m-d_100000.rb=============
Rehearsal --------------------------------------------------
mri 2.4.1 0.000000 0.000000 0.220000 ( 0.250900)
jruby 9.1.9.0 0.000000 0.010000 17.000000 ( 10.515667)
jruby (master) 0.000000 0.000000 9.090000 ( 4.282992)
---------------------------------------- total: 26.310000sec
user system total real
mri 2.4.1 0.000000 0.000000 0.200000 ( 0.209632)
jruby 9.1.9.0 0.000000 0.000000 17.420000 ( 10.452343)
jruby (master) 0.000000 0.000000 9.010000 ( 4.304226)
============bench/strptime_Y-m-d_1000000.rb============
Rehearsal --------------------------------------------------
mri 2.4.1 0.000000 0.000000 1.190000 ( 1.217097)
jruby 9.1.9.0 0.000000 0.000000 60.310000 ( 58.454039)
jruby (master) 0.000000 0.000000 12.350000 ( 8.124656)
---------------------------------------- total: 73.850000sec
user system total real
mri 2.4.1 0.000000 0.000000 1.260000 ( 1.362743)
jruby 9.1.9.0 0.000000 0.000000 60.650000 ( 59.166195)
jruby (master) 0.000000 0.000000 12.170000 ( 7.638632)
===========bench/strptime_Y-m-d_10000000.rb============
Rehearsal --------------------------------------------------
mri 2.4.1 0.000000 0.000000 11.620000 ( 12.800979)
jruby 9.1.9.0 0.000000 0.000000 496.830000 (557.412383)
jruby (master) 0.000000 0.000000 39.220000 ( 39.364392)
--------------------------------------- total: 547.670000sec
user system total real
mri 2.4.1 0.000000 0.000000 11.970000 ( 12.952664)
jruby 9.1.9.0 0.000000 0.000000 482.880000 (516.068042)
jruby (master) 0.000000 0.000000 36.650000 ( 35.192336)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment