This is a hash class that holds a maximum number of elements. If adding an element causes the hash to grow over this size, the least recently used element is removed. Elements in the hash are maintained in LRU order.
Useful for implementing in-process caches where memory growth control is desired.
Example:
myhash = LRUHash.new myhash.max = 2 myhash['a'] = 'apples' myhash['b'] = 'banana' myhash.length # => 2 myhash['c'] = 'cookie' myhash.length # => 2 myhash['a'] # => nil
Add this line to your application’s Gemfile:
gem 'lruhash'
And then execute:
$ bundle
Or install it yourself as:
$ gem install lruhash
require 'lruhash'
-
Fork it
-
Create your feature branch (‘git checkout -b my-new-feature`)
-
Commit your changes (‘git commit -am ’Added some feature’‘)
-
Push to the branch (‘git push origin my-new-feature`)
-
Create new Pull Request
This was forked from github.com/oldmoe/lruhash and modernized. Thanks to oldmoe for the first version.