IOException и FileNotFoundException - PullRequest
       30

IOException и FileNotFoundException

1 голос
/ 27 января 2011

В этом коде есть некоторые ошибки:

Ошибка (18,40): незарегистрированное исключение java.io.FileNotFoundException;должен быть перехвачен или объявлен как брошенный Ошибка (19,42): незарегистрированное исключение java.io.IOException;должен быть перехвачен или объявлен как выброшенный

Но когда генерируются исключения FileNotFound и IOException, компилятор показывает эту ошибку:

Ошибка (15,27): removeEldestEntry (java.util.Map.Entry) в не может переопределить removeEldestEntry (java.util.Map.Entry) в java.util.LinkedHashMap;переопределенный метод не генерирует java.io.IOException

В чем проблема?Код здесь:

package client;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
import java.io.IOException;
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)  {
        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;
    }

};


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 ]

2 голосов
/ 03 июля 2012

Попробуйте это ..

package client;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.util.LinkedHashMap;
import java.util.Map;

public class Level1 {

    private static final int max_cache = 50;
    private Map cache = new LinkedHashMap(max_cache, .75F, true) {

        @Override
        protected boolean removeEldestEntry(Map.Entry eldest) {
            boolean removed = super.removeEldestEntry(eldest);
            if (removed) {
                FileOutputStream fos;
                try {
                    fos = new FileOutputStream("t.tmp");

                    ObjectOutputStream oos = new ObjectOutputStream(fos);

                    oos.writeObject(eldest.getValue());

                    oos.close();

                } catch (IOException ex) {
                    System.err.println("IOException!!");
                } catch (FileNotFoundException ex) {
                    System.err.println("FileNotFoundException!!");
                }
            }
            return removed;
        }
    };

    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());

        }

    }
}
1 голос
/ 27 января 2011

Вам необходимо обработать исключение FileNotFoundException внутри метода removeEldestEntry (обработать как, поймать и зарегистрировать его).Вы не можете прикреплять новые исключения к сигнатуре метода при переопределении метода, потому что тогда ваш подкласс больше не будет заменять то, что вы подклассируете.

В противном случае найдите другой способ сделать это такчто ваш removeEldestEntry помещает записи в очередь, а кто-то еще читает очередь и выполняет сериализацию в файл.На самом деле после прочтения Javadoc кажется, что должно быть лучшее место для размещения этой логики, тот же код, который фактически выполняет удаление, вероятно, будет лучшим местом для сериализации.

...