Философия Java3
вернуться

Эккель Брюс

Шрифт:

}

}

// Чтение файла с разбиением по регулярному выражению: public TextFi1e(String fileName. String splitter) {

super(Arrays.asLi st(readCfi1eName).splitCsplitter))); // Вызов splitO часто оставляет пустой объект // String в начальной позиции: if(get(0) equalsC")) remove(O);

}

// Обычное построчное чтение: public TextFi1e(String fileName) { this(fileName, "\n");

}

public void writeCString fileName) { try {

PrintWriter out = new PrintWriterC

new FileCfil eName). getAbsol uteFi 1 eO);

try {

forCString item : this)

out.println(item);

} finally {

out.closeO;

}

} catch(IOException e) {

throw new RuntimeException(e);

}

}

// Простая проверка :

public static void main(String[] args) {

String file = read("TextFile.java"); writeCtest.txt", file);

TextFile text = new TextFileCtest.txt"); text.wri te("test2.txt");

// Разбиение на уникальный отсортированный список слов: TreeSet<String> words = new TreeSet<String>(

new TextFileC"TextFile.java". "WW+")); // Вывод слов, начинающихся с прописной буквы-System.out.pri ntln(words.headSet("a"));

}

} /* Output:

[0. ArrayList. Arrays. Break. BufferedReader. BufferedWriter. Clean. Display. File.

FileReader, FileWriter, IOException. Normally. Output. PrintWriter. Read. Regular.

RuntimeException. Simple. Static. String. StringBuilder. System, TextFile, Tools,

TreeSet. W. Write]

*///:-

Метод read присоединяет каждую строку к StringBuilder, а за ней присоединяется перевод строки, удаленный при чтении. Затем возвращается объект String, содержащий весь файл. Метод write открывает файл и записывает в него текст.

Обратите внимание: к каждой операции открытия файла добавляется парный вызов close в секции finally. Тем самым обеспечивается гарантированное закрытие файла после завершения работы.

Конструктор использует метод read для превращения файла в String, после чего он вызывает метод String.split, чтобы разбить результат на строки. В качестве разделителя используются символы новой строки (если вы будете часто использовать этот класс, то, возможно, захотите переписать этот конструктор, чтобы он работал эффективнее). К сожалению, аналогичного метода для соединения строк нет, так что для записи строк придется обойтись нестатическим методом write.

Так как класс должен упростить процесс чтения и записи файлов, все исключения IOException преобразуются в RuntimeException, чтобы пользователю не пришлось создавать блоки try/catch. Возможно, вы предпочтете создать другую версию, которая возвращает IOException вызывающей стороне.

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

Стандартный ввод/вывод

Термин «стандартный ввод/вывод» возник еще в эпоху UNIX (и в некоторой форме имеется и в Windows, и во многих других операционных системах). Он означает единственный поток информации, используемый программой. Вся информация программы приходит из стандартного ввода (standard input), все данные записываются в стандартный вывод (standard output), а все ошибки программы передаются в стандартный поток для ошибок (standard error). Значение стандартного ввода/вывода состоит в том, что программы легко соединять в цепочку, где стандартный вывод одной программы становится стандартным вводом другой программы. Это мощный инструмент.

Чтение из стандартного потока ввода

Следуя модели стандартного ввода/вывода, Java определяет необходимые потоки для стандартного ввода, вывода и ошибок: System.in, System.out и System.err. На многих страницах книги вы не раз могли наблюдать процесс записи в стандартный вывод System.out, для которого уже надстроен класс форматирования данных PrintStream. Поток для ошибок System.err схож со стандартным выводом, а стандартный ввод System.in представляет собой «низкоуровневый» поток InputStream без дополнительных надстроек. Это значит, что потоки System, out и System.err можно использовать напрямую, в то время как стандартный ввод System.in желательно надстраивать.

Обычно чтение осуществляется построчно, методом readLine, поэтому имеет смысл буферизовать стандартный ввод System.in посредством BufferedReader. Чтобы сделать это, предварительно следует конвертировать поток System.in в считывающее устройство Reader посредством класса-преобразователя InputStreamReader. Следующий пример просто отображает на экране последнюю строку, введенную пользователем (эхо-вывод):

//• io/Echo java

// Чтение из стандартного ввода

// {RunByHand}

import java io.*;

  • Читать дальше
  • 1
  • ...
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • ...

Private-Bookers - русскоязычная библиотека для чтения онлайн. Здесь удобно открывать книги с телефона и ПК, возвращаться к сохраненной странице и держать любимые произведения под рукой. Материалы добавляются пользователями; если считаете, что ваши права нарушены, воспользуйтесь формой обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • help@private-bookers.win

Подпишитесь на рассылку: