Содержание

  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. Для подсчета хеш-суммы используйте алгоритм SHA-1 (поддержка есть в стандартной библиотеке).
    5. Если при чтении файла возникают ошибки, укажите в качестве его хеш-суммы 40 нулей.
    6. Кодировка входного и выходного файлов — UTF-8.
    7. Если родительская директория выходного файла не существует, то соответствующий путь надо создать.
    8. Размеры файлов могут превышать размер оперативной памяти.
    9. Пример
      Входной файл
      samples/1
      samples/12
      samples/123
      samples/1234
      samples/1
      samples/binary
      samples/no-such-file
                              
      Выходной файл
      356a192b7913b04c54574d18c28d46e6395428ab samples/1
      7b52009b64fd0a2a49e6d8a939753077792b0554 samples/12
      40bd001563085fc35165329ea1ff5c5ecbdbbeef samples/123
      7110eda4d09e062aa5e4a390b0a572ac0d2c0220 samples/1234
      356a192b7913b04c54574d18c28d46e6395428ab samples/1
      4916d6bdb7f78e6803698cab32d1586ea457dfc8 samples/binary
      0000000000000000000000000000000000000000 samples/no-such-file
                              
  2. Сложный вариант:
    1. Разработайте класс RecursiveWalk, осуществляющий подсчет хеш-сумм файлов в директориях.
    2. Входной файл содержит список файлов и директорий, которые требуется обойти. Обход директорий осуществляется рекурсивно.
    3. Пример:
      Входной файл
      samples/binary
      samples
      samples/no-such-file
                              
      Выходной файл
      4916d6bdb7f78e6803698cab32d1586ea457dfc8 samples/binary
      356a192b7913b04c54574d18c28d46e6395428ab samples/1
      7b52009b64fd0a2a49e6d8a939753077792b0554 samples/12
      40bd001563085fc35165329ea1ff5c5ecbdbbeef samples/123
      7110eda4d09e062aa5e4a390b0a572ac0d2c0220 samples/1234
      4916d6bdb7f78e6803698cab32d1586ea457dfc8 samples/binary
      0000000000000000000000000000000000000000 samples/no-such-file
                              
  3. При выполнении задания следует обратить внимание на:
    • Дизайн и обработку исключений, диагностику ошибок.
    • Программа должна корректно завершаться даже в случае ошибки.
    • Корректная работа с вводом-выводом.
    • Отсутствие утечки ресурсов.
  4. Требования к оформлению задания.
    • Проверяется исходный код задания.
    • Весь код должен находиться в пакете info.kgeorgiy.ja.фамилия.walk.

Репозиторий курса