Skip to content

jeromefroe/clock_cache

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CLOCK Cache

Build Status codecov crates.io docs.rs License

Documentation

An implemenation of a CLOCK cache as first described in A Paging Experiment with the Multics System.

Example

Below is a simple example of how to instantiate a CLOCK cache.

extern crate clock_cache;

use clock_cache::ClockCache;

fn main() {
        let mut cache = ClockCache::new(2);
        cache.put("apple", "red");
        cache.put("banana", "yellow");

        assert_eq!(*cache.get(&"apple").unwrap(), "red");
        assert_eq!(*cache.get(&"banana").unwrap(), "yellow");
        assert!(cache.get(&"pear").is_none());

        cache.put("pear", "green");

        assert_eq!(*cache.get(&"pear").unwrap(), "green");
        assert_eq!(*cache.get(&"banana").unwrap(), "yellow");
        assert!(cache.get(&"apple").is_none());
}

About

A CLOCK cache implementation

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages