[#35631] [Ruby 1.9 - Bug #4558][Open] TestSocket#test_closed_read fails after r31230 — Tomoyuki Chikanaga <redmine@...>

23 messages 2011/04/06

[#35632] [Ruby 1.9 - Bug #4559][Open] Proc#== does not match the documented behaviour — Adam Prescott <redmine@...>

13 messages 2011/04/06

[#35637] [Ruby 1.9 - Bug #4561][Open] 1.9.2 requires parentheses around argument of method call in an array, where 1.8.7 did not — Dave Schweisguth <redmine@...>

9 messages 2011/04/07

[#35666] caching of the ancestor chain — Xavier Noria <fxn@...>

Why does Ruby cache the ancestors chain? I mean, not why the implementation implies that, but why it works that way conceptually.

9 messages 2011/04/09

[#35734] [Ruby 1.9 - Feature #4574][Open] Numeric#within — redmine@...

16 messages 2011/04/13

[#35753] [Ruby 1.9 - Bug #4576][Open] Range#step miss the last value, if end-exclusive and has float number — redmine@...

61 messages 2011/04/14
[#39566] [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Marc-Andre Lafortune <ruby-core@...> 2011/09/15

[#39590] [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Marc-Andre Lafortune <ruby-core@...> 2011/09/16

[#39593] Re: [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Tanaka Akira <akr@...> 2011/09/16

2011/9/17 Marc-Andre Lafortune <ruby-core@marc-andre.ca>:

[#39608] Re: [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Masahiro TANAKA <masa16.tanaka@...> 2011/09/17

I have not been watching ruby-core, but let me give a comment for this issue.

[#35765] [Ruby 1.9 - Bug #4579][Open] SecureRandom + OpenSSL may repeat with fork — redmine@...

27 messages 2011/04/15

[#35866] [Ruby 1.9 - Bug #4603][Open] lib/csv.rb: when the :encoding parameter is not provided, the encoding of CSV data is treated as ASCII-8BIT — yu nobuoka <nobuoka@...>

13 messages 2011/04/24

[#35879] [Ruby 1.9 - Bug #4610][Open] Proc#curry behavior is inconsistent with lambdas containing default argument values — Joshua Ballanco <jballanc@...>

11 messages 2011/04/25

[#35883] [Ruby 1.9 - Bug #4611][Open] [BUG] Segementation fault reported — Deryl Doucette <me@...>

15 messages 2011/04/25

[#35895] [Ruby 1.9 - Feature #4614][Open] [RFC/PATCH] thread_pthread.c: lower RUBY_STACK_MIN_LIMIT to 64K — Eric Wong <normalperson@...>

10 messages 2011/04/25

[ruby-core:35692] Re: caching of the ancestor chain

From: Charles Oliver Nutter <headius@...>
Date: 2011-04-10 23:08:24 UTC
List: ruby-core #35692
On Fri, Apr 8, 2011 at 7:56 PM, Yukihiro Matsumoto <matz@ruby-lang.org> wrote:
> Hi,
>
> In message "Re: [ruby-core:35667] Re: caching of the ancestor chain"
>    on Sat, 9 Apr 2011 09:40:59 +0900, Xavier Noria <fxn@hashref.com> writes:
>
> |So I wonder whether this is a design sacrifice for optimization purposes.
>
> Yes, kind of.  If you can find a way to implement "proper" mixin
> relationship as efficient as it currently is, I'd love to take it.

What's actually slow about this? JRuby caches nothing but runs the
following benchmark 3x faster than 1.9.2p160 (and it's not Ruby
execution performance):

cls = Class.new
20.times { cls = Class.new(cls) }
5.times { puts Benchmark.measure { 1000000.times { cls.ancestors } } }

~/projects/jruby ➔ jruby -rbenchmark -e "cls = Class.new; 20.times {
cls = Class.new(cls) }; 5.times { puts Benchmark.measure {
1000000.times { cls.ancestors } } }"
  1.002000   0.000000   1.002000 (  0.956000)
  0.510000   0.000000   0.510000 (  0.511000)
  0.474000   0.000000   0.474000 (  0.474000)
  0.493000   0.000000   0.493000 (  0.493000)
  0.466000   0.000000   0.466000 (  0.466000)

~/projects/jruby ➔ ruby1.9 -rbenchmark -e "cls = Class.new; 20.times {
cls = Class.new(cls) }; 5.times { puts Benchmark.measure {
1000000.times { cls.ancestors } } }"
  1.350000   0.060000   1.410000 (  1.450674)
  1.370000   0.070000   1.440000 (  1.511301)
  1.350000   0.050000   1.400000 (  1.463408)
  1.350000   0.060000   1.410000 (  1.466519)
  1.360000   0.070000   1.430000 (  1.478440)

Am I misunderstanding the original question?

- Charlie

In This Thread