File: bench_java_coll_member.rb

package info (click to toggle)
jruby 9.3.9.0%2Bds-8
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 80,856 kB
  • sloc: ruby: 517,823; java: 260,094; xml: 31,930; ansic: 5,777; yacc: 4,973; sh: 1,163; makefile: 105; jsp: 48; tcl: 40; exp: 11
file content (73 lines) | stat: -rw-r--r-- 2,054 bytes parent folder | download | duplicates (4)
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
require 'java'
require 'benchmark'

TIMES = (ARGV[0] || 5).to_i

CONTENTS = (1..36).to_a

TIMES.times do
  Benchmark.bm(10) do |bm|
    bm.report('ArrayList#include? hit ') do
      list = java.util.ArrayList.new CONTENTS
      hit = 32
      1_000_000.times { list.include?(hit) }
    end
    bm.report('ArrayList#include? miss') do
      list = java.util.ArrayList.new CONTENTS
      miss = 0
      1_000_000.times { list.include?(miss) }
    end
    bm.report('ArrayList#contains hit ') do
      list = java.util.ArrayList.new CONTENTS
      hit = 32
      1_000_000.times { list.contains(hit) }
    end
    bm.report('ArrayList#contains miss') do
      list = java.util.ArrayList.new CONTENTS
      miss = 0
      1_000_000.times { list.contains(miss) }
    end

    bm.report('HashSet#include? hit   ') do
      list = java.util.HashSet.new CONTENTS
      hit = 32
      1_000_000.times { list.include?(hit) }
    end
    bm.report('HashSet#include? miss  ') do
      list = java.util.HashSet.new CONTENTS
      miss = 0
      1_000_000.times { list.include?(miss) }
    end
    bm.report('HashSet#contains hit   ') do
      list = java.util.HashSet.new CONTENTS
      hit = 32
      1_000_000.times { list.contains(hit) }
    end
    bm.report('HashSet#contains miss  ') do
      list = java.util.HashSet.new CONTENTS
      miss = 0
      1_000_000.times { list.contains(miss) }
    end

    bm.report('LHashSet#include? hit  ') do
      list = java.util.LinkedHashSet.new CONTENTS
      hit = 32
      1_000_000.times { list.include?(hit) }
    end
    bm.report('LHashSet#include? miss ') do
      list = java.util.LinkedHashSet.new CONTENTS
      miss = 0
      1_000_000.times { list.include?(miss) }
    end
    bm.report('LHashSet#contains hit  ') do
      list = java.util.LinkedHashSet.new CONTENTS
      hit = 32
      1_000_000.times { list.contains(hit) }
    end
    bm.report('LHashSet#contains miss ') do
      list = java.util.LinkedHashSet.new CONTENTS
      miss = 0
      1_000_000.times { list.contains(miss) }
    end
  end
end