Ребята, я реализую простой пример двухуровневого кеша в Java: 1-й уровень - это мемориальный, 2-й - файловая система
Я новичок в Java и делаю это только для понимания кеширования в Java.И извините за мой английский, этот язык не является родным для меня:)
Я прошел 1-й уровень, используя класс LinkedHashMap и метод removeEldestEntry, и он выглядит так:
import java.util.*;
public class level1 {
private static final int max_cache = 50;
private Map cache = new LinkedHashMap(max_cache, .75F, true) {
protected boolean removeEldestEntry(Map.Entry eldest) {
return size() > max_cache;
}
};
public level1() {
for (int i = 1; i < 52; i++) {
String string = String.valueOf(i);
cache.put(string, string);
System.out.println("\rCache size = " + cache.size() +
"\tRecent value = " + i +
" \tLast value = " +
cache.get(string) + "\tValues in cache=" +
cache.values());
}
}
СейчасЯ собираюсь закодировать мой 2-й уровень.Какой код, методы, которые я должен написать для реализации этих задач:
1) Когда кэш 1-го уровня заполнен, значение не должно быть удалено с помощью removeEldestEntry, но оно должно быть перемещено на 2-й уровень (в файл)
2) Когда новые значения добавляются на 1-й уровень, сначала это значение следует проверить в файле (2-й уровень), а если оно существует, его следует переместить со 2-го на 1-й уровень.
И я попытался использовать LRUMap дляобновить мой 1-й уровень, но компилятор не может найти класс LRUMap в библиотеке, в чем проблема?Может быть, нужен специальный синтаксис?