SimpleLruPage
-
class SimpleLruPage
Bases:
LinkedListNode
One atomic piece that may be managed by a
SimpleLru
chain. To use this class, inherit from it and overrideevict_lru()
.Inheritance diagram
-
explicit SimpleLruPage(std::size_t lru_size)
-
SimpleLruPage(SimpleLruPage const ©)
-
void enqueue_lru(SimpleLru *lru)
Adds the page to the LRU for the first time, or marks it recently-accessed if it has already been added.
If lru is NULL, it means to remove this page from its LRU.
-
virtual void evict_lru(void)
Evicts the page from the LRU. Called internally when the LRU determines that it is full. May also be called externally when necessary to explicitly evict the page.
It is legal for this method to either evict the page as requested, do nothing (in which case the eviction will be requested again at the next epoch), or requeue itself on the tail of the queue (in which case the eviction will be requested again much later).
-
SimpleLru *get_lru(void) const
Returns the LRU that manages this page, or NULL if it is not currently managed by any LRU.
-
std::size_t get_lru_size(void) const
Returns the size of this page as reported to the LRU, presumably in bytes.
-
void mark_used_lru(void) const
-
void mark_used_lru(SimpleLru *lru)
To be called when the page is used; this will move it to the tail of the
SimpleLru
queue it is already on.This method is const because it’s not technically modifying the contents of the page itself.
To be called when the page is used; this will move it to the tail of the specified
SimpleLru
queue.
-
virtual void output(std::ostream &out) const
-
void set_lru_size(std::size_t lru_size)
Specifies the size of this page, presumably in bytes, although any unit is possible.
-
virtual void write(std::ostream &out, int indent_level) const
-
explicit SimpleLruPage(std::size_t lru_size)