From: "funny_falcon (Yura Sokolov)" Date: 2013-05-20T16:28:24+09:00 Subject: [ruby-core:55080] [ruby-trunk - Feature #8426] Implement class hierarchy method caching Issue #8426 has been updated by funny_falcon (Yura Sokolov). Charlie, why sa_index_t is uint64_t ? it really should be 32bit for better CPU cache locality. Yes, it will limits ID to 32bit values, but ID should not increase to greater values, otherwise it is a memory leak. ---------------------------------------- Feature #8426: Implement class hierarchy method caching https://bugs.ruby-lang.org/issues/8426#change-39451 Author: charliesome (Charlie Somerville) Status: Open Priority: Normal Assignee: Category: Target version: =begin This patch adds class hierarchy method caching to CRuby. This is the algorithm used by JRuby and Rubinius. Currently, Ruby's method caches can only be expired globally. This means libraries that dynamically define methods or extend objects at runtime (eg. OpenStruct) can cause quite a significant performance hit. With this patch, each class carries a monotonically increasing sequence number. Whenever an operation which would ordinarily cause a global method cache invalidation is performed, the sequence number on the affected class and all subclasses (classes hold weak references to their subclasses) is incremented, invalidating only method caches for those classes. In this patch I've also split the (({getconstant})) VM instruction into two separate instructions - (({getclassconstant})) and (({getcrefconstant})). It's hoped that (({getclassconstant})) can start using class hierarchy caching with not much more effort. This change does affect compatibility in a minor way. Without this patch, (({nil::SomeConstant})) will look up (({SomeConstant})) in the current scope in CRuby (but not JRuby or Rubinius). With this patch, (({nil::SomeConstant})) will raise an exception. The patch and all its commits can be viewed here: https://github.com/charliesome/ruby/compare/trunk...klasscache-trunk Big thanks to James Golick, who originally wrote this patch for Ruby 1.9.3. =end -- http://bugs.ruby-lang.org/