File: bench_delegate.rb

package info (click to toggle)
jruby 1.5.1-1%2Bdeb6u1
  • links: PTS, VCS
  • area: non-free
  • in suites: squeeze-lts
  • size: 47,024 kB
  • ctags: 74,144
  • sloc: ruby: 398,155; java: 169,506; yacc: 3,782; xml: 2,469; ansic: 415; sh: 279; makefile: 78; tcl: 40
file content (17 lines) | stat: -rw-r--r-- 591 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
require 'benchmark'
require 'delegate'

TIMES = (ARGV[0] || 1).to_i
TIMES.times {
  Benchmark.bm(30) {|bm|
    obj1 = ''
    obj2 = Object.new
    def obj2.to_str(); 'foo'; end
    dele1 = SimpleDelegator.new(obj1)
    dele2 = SimpleDelegator.new(obj2)
    bm.report("control, direct calls, native") { 10_000_000.times { obj1.to_str }}
    bm.report("SimpleDelegate wrapper, native") { 10_000_000.times { dele1.to_str }}
    bm.report("control, direct calls, ruby") { 10_000_000.times { obj2.to_str }}
    bm.report("SimpleDelegate wrapper, ruby") { 10_000_000.times { dele2.to_str }}
  }
}