-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathlru_map.hpp
53 lines (42 loc) · 1.25 KB
/
lru_map.hpp
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
#pragma once
#include <list>
#include <unordered_map>
#include <optional>
template<typename key_t, typename value_t>
class lru_map {
public:
lru_map(const size_t p_max_size): m_max_size(p_max_size) {};
void
insert(const key_t &p_key, const value_t &p_value)
{
const auto l_iterator = m_map.find(p_key);
if (l_iterator != m_map.end()) {
l_iterator->second->second = p_value;
m_list.splice(m_list.begin(), m_list, l_iterator->second);
} else {
m_list.push_front(std::pair<key_t, value_t>{p_key, p_value});
m_map[p_key] = m_list.begin();
}
if (m_map.size() > m_max_size) {
m_map.erase(m_list.back().first);
m_list.pop_back();
}
}
std::optional<value_t>
lookup(const key_t &p_key) const
{
const auto l_iterator = m_map.find(p_key);
if (l_iterator != m_map.end()) {
return std::optional<value_t>(l_iterator->second->second);
} else {
return std::nullopt;
}
}
private:
const size_t m_max_size;
std::list<std::pair<key_t, value_t>> m_list;
std::unordered_map<
key_t,
typename std::list<std::pair<key_t, value_t>>::iterator
> m_map;
};