У меня есть файл с некоторой информацией, как я могу прочитать всю информацию?

Name names;    
try (FileInputStream fileInputStream = new FileInputStream(file)) {
            ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream);
            names = (Name) objectInputStream.readObject();
        } catch (IOException | ClassNotFoundException e) {
            e.printStackTrace();
        }
2
Oppo 25 Ноя 2018 в 14:51

1 ответ

Лучший ответ

У вас есть несколько решений, все в зависимости от ввода:

  • Вы можете выполнять итерацию до тех пор, пока поток не будет полностью израсходован: я думаю, что это худшее решение из тех, что я вам предлагаю. Это хуже, потому что вы проверяете, был ли достигнут EOF, в то время как вы должны знать, когда вы закончите (например, ваш формат файла неправильный).

    Set<Name> result = new HashSet<>();
    try { 
      for (;;) { 
        result.add((Name)objectInputStream.readObject());
      }
    } catch (EOFException e) {
      // End of stream
    } 
    return result;
    
  • При создании ввода сериализуйте коллекцию и вызовите для нее readObject(). Serialization должен иметь возможность читать коллекцию, если каждый объект реализует Serializable.

    static void write(Path path, Set<Name> names) throws IOException {
      try (OutputStream os = Files.newOutputStream(path);
           ObjectOutputStream oos = new ObjectOutputStream(os)) {
        oos.writeObject(names);    
      }       
    } 
    
    static Set<Name> read(Path path) throws IOException {
      try (InputStream is = Files.newInputStream(path);
           ObjectInputStream ois = new ObjectInputStream(is)) {
        // WARN Files.newInputStream is not buffered; ObjectInputStream might
        // be buffered (I don't remember).
        return (Set<Name>) ois.readObject();
      }
    }
    
  • При создании входных данных вы можете добавить int, указывающий количество читаемых объектов, и перебирать его: это полезно в случае, когда вы действительно не заботитесь о коллекции (HashSet). В результате файл будет меньше (потому что у вас не будет метаданных HashSet).

    int result = objectInputStream.readInt();
    Name[] names = new Name[result]; // do some check on result!
    for (int i = 0; i < result; ++i) {
      names[i] = (Name) objectInputStream.readObject();
    }
    

Кроме того, Set хороши, но поскольку они удаляют дубликаты с помощью hashCode() / equals(), вы можете получить меньше объекта, если ваше определение equals / hashCode изменилось после факт (пример: ваш Name был чувствителен к регистру, а теперь нет, например: new Name("AA").equals(new Name("aa"))).

2
NoDataFound 25 Ноя 2018 в 22:06