removeEldestEntry メソッドを上書きして最古のエントリをファイルに保存するにはどうすればよいですか? また、LinkedHashMap で行ったようにファイルのサイズを制限する方法。コードは次のとおりです。
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());
}
FileOutPutSTream を使用しようとしました:
private Map cache = new LinkedHashMap(max_cache, .75F, true) {
protected boolean removeEldestEntry(Map.Entry eldest) throws IOException {
boolean removed = super.removeEldestEntry(eldest);
if (removed) {
FileOutputStream fos = new FileOutputStream("t.tmp");
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(eldest.getValue());
oos.close();
}
return removed;
}
しかし、私はエラーを得ました
エラー (15,27): removeEldestEntry (java.util.Map.Entry) は、java.util.LinkedHashMap の removeEldestEntry (java.util.Map.Entry) をオーバーライドできません。オーバーライドされたメソッドは java.io.IOException をスローしません
IOExecptio がないと、コンパイラは IOexception と Filenotfoundexception の処理を要求します。多分別の方法が存在しますか?サンプルコードを教えてください。私はJavaが初めてで、2レベルキャッシングの基本原則を理解しようとしています。どうも