summaryrefslogtreecommitdiff
path: root/bench/bench_closure_VrV.rb
blob: 20a92a461529f44aa781f2c891774e27ed581536 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
require File.expand_path(File.join(File.dirname(__FILE__), "bench_helper"))

module LibTest
  extend FFI::Library
  ffi_lib LIBTEST_PATH
  callback :closureVrV, [ ], :void
  
  attach_function :ffi_bench, :testClosureVrV, [ :closureVrV ], :void
  attach_function :threaded_bench, :testThreadedClosureVrV, [ :closureVrV, :int ], :void
  
  def self.rb_bench(&block)
    yield
  end
end

unless RUBY_PLATFORM == "java" && JRUBY_VERSION < "1.3.0"
  require 'dl'
  require 'dl/import'
  module LibTest
    if RUBY_VERSION >= "1.9.0"
      extend DL::Importer
    else
      extend DL::Importable
    end
    dlload LIBTEST_PATH
    extern "int returnInt()"
  end
end

puts "Benchmark [ ], :void closure block performance, #{ITER}x calls"
10.times {
  puts Benchmark.measure {
    ITER.times { LibTest.ffi_bench { } }
  }
}

puts "Benchmark [ ], :void pre-allocated function pointer performance, #{ITER}x calls"
10.times {
  fn = FFI::Function.new(:void, []) {}
  puts Benchmark.measure {
    ITER.times { LibTest.ffi_bench fn }
  }
}

puts "Benchmark [ ], :void pre-allocated closure performance, #{ITER}x calls"
10.times {
  proc = lambda {}
  puts Benchmark.measure {
    ITER.times { LibTest.ffi_bench proc }
  }
}

puts "Benchmark [ ], :void non-ruby thread closure performance, #{ITER}x calls"
10.times {
  fn = FFI::Function.new(:void, []) {}
  puts Benchmark.measure {
    LibTest.threaded_bench(fn, ITER)
  }
}


#unless RUBY_PLATFORM == "java" && JRUBY_VERSION < "1.3.0"
#puts "Benchmark DL void bench() performance, #{ITER}x calls"
#10.times {
#  puts Benchmark.measure {
#    ITER.times { LibTest.returnInt }
#  }
#}
#end

puts "Benchmark ruby method(no arg)  performance, #{ITER}x calls"
10.times {
  puts Benchmark.measure {
    ITER.times { LibTest.rb_bench {} }
  }
}