Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
tree: 1679870e21
Fetching contributors…

Cannot retrieve contributors at this time

file 79 lines (65 sloc) 2.127 kb
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 78 79
require 'benchmark'


SIMPLE_TIMES = 10_000_000
GROWTH_TIMES = 8_000

# prepare dummy objects
default_object = Class.new.new
default_object.instance_variable_set(:@foo,2)

disposable_objects = (0..10).map{Class.new.new}

simple_reader = proc do |o|
  result = nil;
  for i in (0..SIMPLE_TIMES)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
    result = o.instance_variable_get(:@foo)
  end
  result
end

simple_writer = proc do |o|
  for i in (0..SIMPLE_TIMES)
    o.instance_variable_set(:@foo,0)
    o.instance_variable_set(:@foo,1)
    o.instance_variable_set(:@foo,2)
    o.instance_variable_set(:@foo,3)
    o.instance_variable_set(:@foo,4)
    o.instance_variable_set(:@foo,5)
    o.instance_variable_set(:@foo,6)
    o.instance_variable_set(:@foo,7)
    o.instance_variable_set(:@foo,8)
    o.instance_variable_set(:@foo,9)
  end
end

Benchmark.bmbm do |b|
  b.report "baseline x#{SIMPLE_TIMES}" do
    for i in (0..SIMPLE_TIMES)
      1
    end
  end

  b.report "single threaded reads x#{SIMPLE_TIMES}" do
    simple_reader.call(default_object)
  end
  
  b.report "single threaded writes x#{SIMPLE_TIMES}" do
    simple_writer.call(default_object)
  end
  
  b.report "two reader threads x#{SIMPLE_TIMES}" do
    t1 = Thread.new{simple_reader.call(default_object)}
    t2 = Thread.new{simple_reader.call(default_object)}
    t1.join;t2.join
  end
  
  b.report "one reader, one writer x#{SIMPLE_TIMES}" do
    t1 = Thread.new{simple_reader.call(default_object)}
    t2 = Thread.new{simple_writer.call(default_object)}
    t1.join;t2.join
  end

  b.report "single threaded growth x#{GROWTH_TIMES}" do
    o = disposable_objects.pop
    (0..GROWTH_TIMES).each{|i| o.instance_variable_set(:"@bar_#{i}",1)}
  end
  

end
Something went wrong with that request. Please try again.