Часть 1. Введение
Тем: 4
Тема 1. Ввод-вывод
Содержание
- Потоки ввода-вывода
- Четыре вида потоков
- Операции с потоками
- Исключения ввода-вывода
- Файловый ввод-вывод и преобразование потоков
- Классы файловых потоков
- Кодировки и преобразование потоков
- Фильтрующие потоки
- Фильтрация
- Буферизация
- Дополнительные возможности потоков
- Эмуляция чтения и записи
- Конкатенация потоков ввода
- Подавление ошибок
- Расширенный ввод-вывод
- Платформонезависимый ввод-вывод
- Файлы с произвольным доступом
- Классы System и Console
- Дескрипторы файлов
- Файлы, каталоги, пути и разделители
- Операции с отдельными файлами
- Листинг каталогов
- Ввод-вывод в Java 7
- Файловые системы и пути
- Операции с отдельными файлами
- Листинг каталогов
- Ввод-вывод и исключения
- Идиома работы с ресурсами
- Работа с несколькими потоками
Примеры
zipДомашнее задание 1. Обход файлов
-
Разработайте класс
Walk
, осуществляющий подсчет хэш-сумм файлов.-
Формат запуска:
java Walk <входной файл> <выходной файл>
- Входной файл содержит список файлов, которые требуется обойти.
-
Выходной файл должен содержать по одной строке для каждого файла.
Формат строки:
<шестнадцатеричная хэш-сумма> <путь к файлу>
- Для подсчета хэш-суммы используйте последние 64 бита SHA-256 (поддержка есть в стандартной библиотеке).
- Если при чтении файла возникают ошибки, укажите в качестве его хэш-суммы все нули.
- Кодировка входного и выходного файлов — UTF-8.
- Размеры файлов могут превышать размер оперативной памяти.
-
Пример
Входной файл samples/1 samples/12 samples/123 samples/1234 samples/1 samples/binary samples/no-such-file
Выходной файл 6b86b273ff34fce1 samples/1 6b51d431df5d7f14 samples/12 a665a45920422f9d samples/123 03ac674216f3e15c samples/1234 6b86b273ff34fce1 samples/1 40aff2e9d2d8922e samples/binary 0000000000000000 samples/no-such-file
-
Формат запуска:
-
Сложный вариант:
-
Разработайте класс
RecursiveWalk
, осуществляющий подсчет хэш-сумм файлов в директориях. - Входной файл содержит список файлов и директорий, которые требуется обойти. Обход директорий осуществляется рекурсивно.
-
Пример:
Входной файл samples/binary samples samples/no-such-file
Выходной файл 40aff2e9d2d8922e samples/binary 6b86b273ff34fce1 samples/1 6b51d431df5d7f14 samples/12 a665a45920422f9d samples/123 03ac674216f3e15c samples/1234 40aff2e9d2d8922e samples/binary 0000000000000000 samples/no-such-file
-
Разработайте класс
-
При выполнении задания следует обратить внимание на:
- Дизайн и обработку исключений, диагностику ошибок.
- Программа должна корректно завершаться даже в случае ошибки.
- Корректная работа с вводом-выводом.
- Отсутствие утечки ресурсов.
- Возможность повторного использования кода.
-
Требования к оформлению задания.
- Проверяется исходный код задания.
-
Весь код должен находиться в пакете
info.kgeorgiy.ja.фамилия.walk
.
Тема 2. Collections Framework
Содержание
- Контейнеры
- Коллекции
- Интерфейс Collection
- Итераторы
- Класс AbstractCollection
- Множества
- Интерфейс Set
- Методы equals и hashCode
- Реализации множеств и базовые классы
- Списки
- Интерфейс List
- Итераторы по спискам
- Реализации списков и базовые классы
- Очереди и деки
- Интерфейс Queue
- Интерфейс Dequeue
- Реализации очередей и деков, базовые классы
- Коллекции
- Отображения
- Интерфейс Map
- Пары и проекции отображений
- Реализации отображений и базовые классы
- Упорядоченные коллекции
- Сравнение элементов и согласованность с equals
- Упорядоченные множества
- Упорядоченные отображения
- Очередь с приоритетами
- Алгоритмы
- Класс Collections
- Класс Arrays
- Устаревшие коллекции
Примеры
zipДомашнее задание 2. Множество на массиве
-
Разработайте класс
ArraySet
, реализующий неизменяемое упорядоченное множество.-
Класс
ArraySet
должен реализовывать интерфейс SortedSet (простой вариант) или NavigableSet (сложный вариант). - Все операции над множествами должны производиться с наилучшей асимптотической эффективностью.
-
Класс
-
При выполнении задания следует обратить внимание на:
- Применение стандартных коллекций.
- Избавление от повторяющегося кода.
- Отсутствие unchecked warnings при компиляции.
- Отсутствие излишних подавленных unchecked warnings.
Тема 3. Лямбда-выражения и потоки
Содержание
- Расширения интерфейсов
- Лямбда-выражения
- Функциональные интерфейсы
- Лямбда-выражения
- Ссылки на методы
- Поддержка лямбда-выражений в основных классах
- Типы-обертки
- Класс Objects
- Стандартные функциональные интерфейсы
- Поддержка лямбда-выражений в Collections Framework
- Необязательные значения
- Компараторы
- Новые методы коллекций и отображений
- Потоки значений
- Применение
- Типы потоков
- Создание и преобразование потоков
- Комбинаторы
- Стандартные коллекторы
- Реализация потоков
- Разбиваемые итераторы
- Обобщенные свертки
- Параллельное исполнение
- Применение
Примеры
zipДомашнее задание 3. Студенты
-
Разработайте класс
StudentDB
, осуществляющий поиск по базе данных студентов.-
Класс
StudentDB
должен реализовывать интерфейсStudentQuery
(простой вариант) илиGroupQuery
(сложный вариант). - Каждый метод должен состоять из ровно одного оператора. При этом длинные операторы надо разбивать на несколько строк.
-
Класс
-
При выполнении задания следует обратить внимание на:
- применение лямбда-выражений и потоков;
- избавление от повторяющегося кода.
Домашнее задание 4. Сплитераторы и коллекторы
-
Разработайте класс
Lambda
, реализующий сплитераторы для деревьев и дополнительные коллекторы.- Простой вариант (интерфейс
EasyLambda
) — реализуйте:- сплитераторы для двоичных деревьев, двоичных деревьев с известным размером, k-ичных деревьев;
- коллекторы первого, последнего, среднего элементов;
- коллекторы общего префикса и суффикса строк.
- Сложный вариант (интерфейс
HardLambda
) — дополнительно реализуйте:- сплитераторы всех видов деревьев над списками элементов;
- коллектор n-ого элемента;
- коллекторы первых и последних n элементов.
- Простой вариант (интерфейс
-
При выполнении задания следует обратить внимание на:
- характеристики создаваемых сплитераторов;
- избавление от повторяющегося кода.
Библиография
Тема 4. Reflection
Содержание
- Введение в Reflection
- Идентификаторы типов (type tokens)
- Информация о типе
- Структура класса
- Поля
- Получение информации
- Чтение и запись значений
- Методы и конструкторы
- Получение информации
- Вызов методов
- Создание объектов
- Вложенные классы
- Поля
- Массивы
- Загрузка классов
- Загрузчики классов
- Иерархия загрузчиков
- Доступ к ресурсам
- Параметры типов
- Интерфейс Type и его потомки
- Generic-массивы
- Посредники
- Создание посредников
- Обработчики вызовов
- Применение посредников
Примеры
zipДомашнее задание 5. Implementor
-
Реализуйте класс
Implementor
, генерирующий реализации классов и интерфейсов.- Аргумент командной строки: полное имя класса/интерфейса, для которого требуется сгенерировать реализацию.
-
В результате работы должен быть сгенерирован java-код класса с суффиксом
Impl
, расширяющий (реализующий) указанный класс (интерфейс). - Сгенерированный класс должен компилироваться без ошибок.
- Сгенерированный класс не должен быть абстрактным.
- Методы сгенерированного класса должны игнорировать свои аргументы и возвращать значения по умолчанию.
-
В задании выделяются три варианта:
- Простой —
Implementor
должен уметь реализовывать только интерфейсы (но не классы). Поддержка generics не требуется. - Сложный —
Implementor
должен уметь реализовывать и классы, и интерфейсы. Поддержка generics не требуется. - Бонусный —
Implementor
должен уметь реализовывать generic-классы и интерфейсы. Сгенерированный код должен иметь корректные параметры типов и не порождать unchecked warnings.
- Простой —
Библиография
Часть 2. Инструменты
Тем: 3
Тема 5. Jar
Содержание
- Jar-файлы
- Инструмент командной строки
- API для работы с Zip, Jar и Gzip
- Манифесты
- Формат
- Основные атрибуты
Домашнее задание 6. Jar Implementor
Это домашнее задание связано с предыдущим и будет приниматься только с ним. Предыдущее домашнее задание отдельно сдать будет нельзя.
-
Создайте
.jar
-файл, содержащий скомпилированныйImplementor
и сопутствующие классы.-
Созданный
.jar
-файл должен запускаться командойjava -jar
. -
Запускаемый
.jar
-файл должен принимать те же аргументы командной строки, что и классImplementor
.
-
Созданный
-
Модифицируйте
Implementor
так, чтобы при запуске с аргументами-jar имя-класса файл.jar
он генерировал.jar
-файл с реализацией соответствующего класса (интерфейса). Для компиляции можно использовать код из тестов. - Вы можете создавать файлы и директории в текущем каталоге, но не за его пределами.
-
Для проверки, кроме исходного кода, также должны быть представлены:
-
скрипт для создания запускаемого
.jar
-файла, в том числе, исходный код манифеста; -
запускаемый
.jar
-файл.
-
скрипт для создания запускаемого
- Сложный вариант. Решение должно быть модуляризовано.
Тема 6. Javadoc
Содержание
- Что такое Javadoc
- Структура Javadoc
- Javadoc-комментарии
- Типы тегов
- Блочные теги
- Общие теги
- Теги методов
- Строчные теги
- Ссылки
- Код и значения
- Применение Javadoc
- Объекты документирования
- Наследование Javadoc
- Компиляция Javadoc
Примеры
zipДомашнее задание 7. Javadoc
Это домашнее задание связано с двумя предыдущими и будет приниматься только с ними. Предыдущие домашнее задание отдельно сдать будет нельзя.
-
Документируйте класс
Implementor
и сопутствующие классы с применением Javadoc.-
Должны быть документированы все классы и все члены классов,
в том числе
private
. - Документация должна генерироваться без предупреждений.
-
Сгенерированная документация должна содержать корректные
ссылки на классы стандартной библиотеки и модулей
info.kgeorgiy.java.advanced.*
.
-
Должны быть документированы все классы и все члены классов,
в том числе
-
Для проверки, кроме исходного кода, также должны быть представлены:
- скрипт для генерации документации (он может рассчитывать, что рядом с вашим репозиторием склонирован репозиторий курса);
- сгенерированная документация.
В последующих домашних заданиях все public
и
protected
сущности должны быть документированы.
Тема 7. Модули
Содержание
- Что такое модули
- Определение
- Объявление
- Module path
- Управление зависимостями
- Подключение зависимостей
- Экспорт пакетов
- Открытие пакетов
- Сервисы
- Определение сервиса
- Реализация сервиса и ее объявление
- Объявление использования сервиса
- Загрузка сервисов
- Модуляризованный JDK
Примеры
zipЧасть 3. Многопоточное программирование
Тем: 4
Тема 8. Введение в многопоточное программирование
Содержание
- Параллельное исполнение
- Развитие параллельных систем
- Потоки и процессы
- Типы параллелизма
- Итеративный
- Рекурсивный
- Обмен сообщениями
- Неделимые операции
- Безусловные
- Условные
- Свойства планировщика
- Потоки
- Создание потоков
- Состояния и свойства потоков
- Завершение потоков
- Механизм прерывания
Примеры
zipДомашнее задание 8. Итеративный параллелизм
-
Реализуйте класс
IterativeParallelism
, который будет обрабатывать списки в несколько потоков. -
В простом варианте должны быть реализованы следующие методы:
argMax(threads, list, comparator)
— индекс первого максимума;argMin(threads, list, comparator)
— индекс первого минимума;indexOf(threads, list, predicate)
— индекс первого элемента, удовлетворяющего предикат;lastIndexOf(threads, list, predicate)
— индекс последнего элемента, удовлетворяющего предикат;sumIndices(threads, list, predicate)
— сумма индексов элементов, удовлетворяющих предикат;
-
В сложном варианте должны быть дополнительно реализованы следующие методы:
indices(threads, list, predicate)
— индексы элементов, удовлетворяющих предикат;filter(threads, list, predicate)
— вернуть список, содержащий элементы удовлетворяющие предикату;map(threads, list, function)
— вернуть список, содержащий результаты применения функции;
-
Во все функции передается параметр
threads
— сколько потоков надо использовать при вычислении. Вы можете рассчитывать, что число потоков относительно мало. - Не следует рассчитывать на то, что переданные компараторы, предикаты и функции работают быстро.
-
Можно сделать O(
threads
), но не O(list.size()
) действий без распараллеливания. - При выполнении задания нельзя использовать Concurrency Utilities и Parallel Streams.
Библиография
- Java Language Specification. Theads and locks
- Concurrency (Java Tutorial)
- Lea D. Concurrent Programming in Java
- Goetz B. Java Concurrency in Practice
- Garg V. Concurrent and Distributed Computing in Java
Тема 9. Взаимодействие потоков
Содержание
- Синхронизация и блокировки
- Синхронизация
- Неявные блокировки
- Активное ожидания
- Мониторы и условия
- Мониторы
- Условия и работа с ними
- Пассивное ожидание
- Внезапные пробуждения
- Модель памяти Java
- Атомарность операций
- Видимость изменений и барьеры
- Упорядоченность изменений
- Volatile-переменные
- Примеры многопоточных программ
- Двусторонний барьер
- Гарантированный тупик
- Уровни безопасности
- Неизменяемые объекты
- Потокобезопасные объекты
- Потоконебезопасные объекты
- Thread-local objects
Примеры
zipДомашнее задание 9. Параллельный запуск
-
Напишите класс
ParallelMapperImpl
, реализующий интерфейсParallelMapper
.public interface ParallelMapper extends AutoCloseable { <T, R> List<R> map( Function<? super T, ? extends R> f, List<? extends T> args ) throws InterruptedException; @Override void close(); }
-
Метод
map
должен параллельно вычислять функциюf
на каждом из указанных аргументов (args
). -
Конструктор
ParallelMapperImpl(int threads)
должен создаватьthreads
рабочих потоков, которые используются для распараллеливания. -
Метод
close
должен останавливать все рабочие потоки. -
К одному
ParallelMapperImpl
могут одновременно обращаться несколько клиентов. - При недостатке потоков для распараллеливания, задания на исполнение должны накапливаться в очереди и обрабатываться в порядке поступления.
- В реализации не должно быть активных ожиданий.
- Код должен находиться в пакете
iterative
. -
Обратите внимание на обработку исключений,
кидаемых функцией
f
.- Исключения не должны приводить к сокращению числа рабочих потоков.
- Сложный вариант.
Исключения должны выкидываться из метода
map
.
-
Метод
-
Доработайте класс
IterativeParallelism
так, чтобы он мог использоватьParallelMapper
.-
Добавьте конструктор
IterativeParallelism(ParallelMapper)
. -
Методы класса должны делить работу на
threads
фрагментов и исполнять их при помощиParallelMapper
. -
При наличии
ParallelMapper
самIterativeParallelism
новые потоки создавать не должен. -
Должна быть возможность одновременного запуска и работы
нескольких клиентов, использующих один
ParallelMapper
.
-
Добавьте конструктор
- При выполнении задания всё ещё нельзя использовать Concurrency Utilities и Parallel Streams.
Библиография
- Java Language Specification. Theads and locks
- Concurrency (Java Tutorial)
- Lea D. Concurrent Programming in Java
- Goetz B. Java Concurrency in Practice
- Garg V. Concurrent and Distributed Computing in Java
Тема 10. Задачи и средства многопоточного программирования
Содержание
- Классические задачи многопоточного программирования
- Доступ к разделяемому ресурсу
- Производители и потребители
- Читатели и писатели
- Обедающие философы
- Задания и работники
- Атомарные операции
- Виды атомарных операций
- CompareAndSet
- Применение атомарных операций
- Помеченные ссылки
- Блокировки и условия
- Блокировки
- Условия
- Блокировки чтения-записи
- Примитивы синхронизации
- Критические секции
- Семафоры
- Барьеры
- Защелки
- Рандеву
- Мониторы
- Решение классических задач многопоточного программирования
- Читатели и писатели
- Обедающие философы
- Задания и работники
Библиография
- Java Concurrency Utilities
- High Level Concurrency Objects (Java Tutorial)
- JSR 166: Concurrency Utilities
- Concurrent Programming with J2SE 5.0
- Эндрюс Г. Основы многопоточного, параллельного и распределенного программирования
- Goetz B. Java concurrency in practice
Тема 11. Concurrency Utilities
Содержание
- Многопоточные коллекции
- Блокирующиеся очереди
- Многопоточные отображения
- Самокопирующиеся коллекции
- Управление заданиями
- Исполнители
- Функции и результаты
- Отложенное исполнение
- Прочие возможности
- Интервалы времени
- Очереди с задержкой
Домашнее задание 10. Web Crawler
-
Напишите потокобезопасный класс
WebCrawler
, который будет рекурсивно обходить сайты.-
Класс
WebCrawler
должен иметь конструкторpublic WebCrawler(Downloader downloader, int downloaders, int extractors, int perHost)
downloader
позволяет скачивать страницы и извлекать из них ссылки;downloaders
— максимальное число одновременно загружаемых страниц;extractors
— максимальное число страниц, из которых одновременно извлекаются ссылки;perHost
— максимальное число страниц, одновременно загружаемых c одного хоста. Для определения хоста следует использовать методgetHost
классаURLUtils
из тестов.
-
Класс
WebCrawler
должен реализовывать интерфейсCrawler
public interface Crawler extends AutoCloseable { Result download(String url, int depth); void close(); }
-
Метод
download
должен рекурсивно обходить страницы, начиная с указанного URL, на указанную глубину и возвращать список загруженных страниц и файлов. Например, если глубина равна 1, то должна быть загружена только указанная страница. Если глубина равна 2, то указанная страница и те страницы и файлы, на которые она ссылается, и так далее. -
Метод
download
может вызываться параллельно в нескольких потоках. - Загрузка и обработка страниц (извлечение ссылок) должна выполняться максимально параллельно, с учетом ограничений на число одновременно загружаемых страниц (в том числе с одного хоста) и страниц, с которых загружаются ссылки.
-
Для распараллеливания разрешается создать
downloaders + extractors
вспомогательных потоков. -
Повторно загружать и/или извлекать ссылки из одной
и той же страницы в рамках одного обхода
(
download
) запрещается. -
Метод
close
должен завершать все вспомогательные потоки.
-
Метод
-
Для загрузки страниц должен применяться
Downloader
, передаваемый первым аргументом конструктора.public interface Downloader { public Document download(final String url) throws IOException; }
-
Метод
download
загружает документ по его адресу (URL). -
Документ позволяет получить ссылки по загруженной странице:
public interface Document { List<String> extractLinks() throws IOException; }
Ссылки, возвращаемые документом, являются абсолютными и имеют схемуhttp
илиhttps
.
-
Метод
-
Должен быть реализован метод
main
, позволяющий запустить обход из командной строки-
Командная строка
WebCrawler url [depth [downloads [extractors [perHost]]]]
-
Для загрузки страниц требуется использовать реализацию
CachingDownloader
из тестов.
-
Командная строка
-
Класс
-
Версии задания
- Простая — не требуется учитывать ограничения
на число одновременных закачек с одного хоста
(
perHost >= downloaders
). - Полная — требуется учитывать все ограничения.
- Бонусная — сделать параллельный обход в ширину.
- Простая — не требуется учитывать ограничения
на число одновременных закачек с одного хоста
(
- Задание подразумевает активное использование Concurrency Utilities, в частности, в решении не должно быть «велосипедов», аналогичных/легко сводящихся к классам из Concurrency Utilities.
Библиография
- JSR 166: Concurrency Utilities
- Concurrent Programming with J2SE 5.0
- Virtual Threads
- Getting to know synchronizers
- Эндрюс Г. Основы многопоточного, параллельного и распределенного программирования
- Goetz B. Java concurrency in practice
Часть 4. Сетевые приложения
Тем: 3
Тема 12. Работа с сетью
Содержание
- Введение
- Стек сетевых протоколов
- Протоколы IPv4 и IPv6
- Протокол TCP
- Протокол UDP
- DNS
- Адреса
- Адреса хостов
- Работа с DNS
- Адреса портов
- Работа с TCP
- Клиентский сокет
- Создание
- Управление ресурсами
- Закрытие части соединения
- Серверный сокет
- Создание
- Прием соединений
- Клиентский сокет
- Работа с UDP
- Датаграммы
- Исходящие
- Входящие
- Сокеты
- Создание
- Отправка и прием данных
- Датаграммы
- URI и URL
- URI
- Понятие об URI
- Структура URI
- Сравнение URI
- URL
- Понятие об URL
- Структура URL
- Сравнение URL
- URI
- Соединения
- Создание соединения
- Жизненный цикл соединения
- Быстрое установление соединения
- Поддержка протоколов
- Работа с HTTP
- Клиент
- Сервер
Примеры
zipТема 13. Сериализация и RMI
Содержание
- Сериализация
- Сериализация и десериализация
- Объектные потоки
- Автоматическая сериализация
- Ручная сериализация
- Настраиваемая сериализация
- Сериализация и версионирование
- Сериализация и дескрипторы
- Концепции RMI
- Предназначение
- Схема работы и стек протоколов
- Удаленные интерфейсы
- Stub и Skeleton
- Распределенная сборка мусора
- RMI Registry
- Применение RMI
Примеры
zipТема 14. Неблокирующий и асинхронный ввод-вывод
Содержание
- Буферы
- Операции
- Чтение и запись
- Байтовые буферы
- Типизированные буферы
- Каналы
- Иерархия каналов
- Байтовые каналы
- Файловые каналы
- Файлы отображаемые в память
- Блокировки
- Сетевые каналы
- Неблокирующий ввод-вывод
- Асинхронные каналы
Примеры
zipЧасть 5. Разное
Тем: 2
Тема 15. Интернационализация и локализация
Содержание
- Локали
- Локализация данных
- Создание ResourceBundle
- Загрузка ResourceBundle
- Использование ResourceBundle
- Форматирование
- Форматирование чисел
- Форматирование дат и времени
- Форматирование сообщений
- Работа с текстом
- Сравнение строк
- Разбиение текста
- Запись текста
Примеры
zipТема 16. Сборка мусора
Содержание
- Сборка мусора
- Сжимающие и копирующие сборщики
- Гипотеза о поколениях и ее применение
- Ссылки
- Типы ссылок
- Очереди ссылок
Примеры
zipЧасть 6. Интерфейс пользователя
Тем: 4
Тема 17. Стандартные компоненты
Примеры
zipТема 18. Обработка событий
Примеры
zipТема 19. Модели
Примеры
zipТема 20. JavaBeans
Часть 7. XML
Тем: 5