78 lines
1.3 KiB
C++
78 lines
1.3 KiB
C++
8 years ago
|
#ifndef CACHE_POLICY_HPP
|
||
|
#define CACHE_POLICY_HPP
|
||
|
|
||
|
#include <unordered_set>
|
||
|
|
||
|
namespace caches
|
||
|
{
|
||
|
|
||
|
template <typename Key>
|
||
|
|
||
|
class ICachePolicy
|
||
|
{
|
||
|
public:
|
||
|
|
||
|
virtual ~ICachePolicy() {}
|
||
|
|
||
|
// handle element insertion in a cache
|
||
|
virtual void Insert(const Key& key) = 0;
|
||
|
|
||
|
// handle request to the key-element in a cache
|
||
|
virtual void Touch(const Key& key) = 0;
|
||
|
|
||
|
// handle element deletion from a cache
|
||
|
virtual void Erase(const Key& key) = 0;
|
||
|
|
||
|
// return a key of a replacement candidate
|
||
|
virtual const Key& ReplCandidate() const = 0;
|
||
|
|
||
|
// clear the cache
|
||
|
virtual void Clear() = 0;
|
||
|
|
||
|
};
|
||
|
|
||
|
template <typename Key>
|
||
|
class NoCachePolicy : public ICachePolicy<Key>
|
||
|
{
|
||
|
public:
|
||
|
|
||
|
NoCachePolicy() = default;
|
||
|
|
||
|
~NoCachePolicy() override = default;
|
||
|
|
||
|
void Insert(const Key& key) override
|
||
|
{
|
||
|
key_storage.emplace(key);
|
||
|
}
|
||
|
|
||
|
void Touch(const Key& key) override
|
||
|
{
|
||
|
// do not do anything
|
||
|
}
|
||
|
|
||
|
void Erase(const Key& key) override
|
||
|
{
|
||
|
key_storage.erase(key);
|
||
|
}
|
||
|
|
||
|
// return a key of a displacement candidate
|
||
|
const Key& ReplCandidate() const override
|
||
|
{
|
||
|
return *key_storage.crbegin();
|
||
|
}
|
||
|
|
||
|
// return a key of a displacement candidate
|
||
|
void Clear() override
|
||
|
{
|
||
|
key_storage.clear();
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
|
||
|
std::unordered_set<Key> key_storage;
|
||
|
};
|
||
|
|
||
|
} // namespace caches
|
||
|
|
||
|
#endif // CACHE_POLICY_HPP
|