Содержание

  1. Потоки ввода-вывода
    1. Четыре вида потоков
    2. Операции с потоками
    3. Исключения ввода-вывода
  2. Файловый ввод-вывод и преобразование потоков
    1. Классы файловых потоков
    2. Кодировки и преобразование потоков
  3. Фильтрующие потоки
    1. Фильтрация
    2. Буферизация
  4. Дополнительные возможности потоков
    1. Эмуляция чтения и записи
    2. Конкатенация потоков ввода
    3. Подавление ошибок
  5. Расширенный ввод-вывод
    1. Платформонезависимый ввод-вывод
    2. Файлы с произвольным доступом
    3. Классы System и Console
  6. Дескрипторы файлов
    1. Файлы, каталоги, пути и разделители
    2. Операции с отдельными файлами
    3. Листинг каталогов
  7. Ввод-вывод в Java 7
    1. Файловые системы и пути
    2. Операции с отдельными файлами
    3. Листинг каталогов
  8. Ввод-вывод и исключения
    1. Идиома работы с ресурсами
    2. Работа с несколькими потоками

Слайды

HTML

Примеры

zip

Домашнее задание 1. Обход файлов

Обход файлов
  1. Разработайте класс Walk, осуществляющий подсчет хеш-сумм файлов.
    1. Формат запуска
      java Walk <входной файл> <выходной файл>
    2. Входной файл содержит список файлов, которые требуется обойти.
    3. Выходной файл должен содержать по одной строке для каждого файла. Формат строки:
      <шестнадцатеричная хеш-сумма> <путь к файлу>
    4. Для подсчета хеш-суммы используйте 64-битную версию алгоритма PJW.
    5. Если при чтении файла возникают ошибки, укажите в качестве его хеш-суммы 0000000000000000.
    6. Кодировка входного и выходного файлов — UTF-8.
    7. Если родительская директория выходного файла не существует, то соответствующий путь надо создать.
    8. Размеры файлов могут превышать размер оперативной памяти.
    9. Пример

      Входной файл

          samples/1
          samples/12
          samples/123
          samples/1234
          samples/1
          samples/binary
          samples/no-such-file
                          

      Выходной файл

          0000000000000031 samples/1
          0000000000003132 samples/12
          0000000000313233 samples/123
          0000000031323334 samples/1234
          0000000000000031 samples/1
          005501015554abff samples/binary
          0000000000000000 samples/no-such-file
                          
  2. Сложный вариант:
    1. Разработайте класс RecursiveWalk, осуществляющий подсчет хеш-сумм файлов в директориях
    2. Входной файл содержит список файлов и директорий, которые требуется обойти. Обход директорий осуществляется рекурсивно.
    3. Пример

      Входной файл

          samples/binary
          samples
          samples/no-such-file
                          

      Выходной файл

          005501015554abff samples/binary
          0000000000000031 samples/1
          0000000000003132 samples/12
          0000000000313233 samples/123
          0000000031323334 samples/1234
          005501015554abff samples/binary
          0000000000000000 samples/no-such-file
                          
  3. При выполнении задания следует обратить внимание на:
    • Дизайн и обработку исключений, диагностику ошибок.
    • Программа должна корректно завершаться даже в случае ошибки.
    • Корректная работа с вводом-выводом.
    • Отсутствие утечки ресурсов.
  4. Требования к оформлению задания.
    • Проверяется исходный код задания.
    • Весь код должен находиться в пакете info.kgeorgiy.ja.фамилия.walk.

Тесты к домашним заданиям