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
|
module Tins
class LRUCache
include Enumerable
class << self
private
my_nil = Object.new.freeze
define_method(:not_exist) do
my_nil
end
end
def initialize(capacity)
@capacity = capacity
@data = {}
end
attr_reader :capacity
def [](key)
case value = @data.delete(key){ not_exist }
when not_exist
nil
else
@data[key] = value
end
end
def []=(key, value)
@data.delete(key)
@data[key] = value
if @data.size > @capacity
@data.delete(@data.keys.first)
end
value
end
def each(&block)
@data.reverse_each(&block)
end
def delete(key)
@data.delete(key)
end
def clear
@data.clear
end
def size
@data.size
end
private
def not_exist
self.class.send(:not_exist)
end
end
end
|