О курсе
Механизмы асинхронности и многопоточности часто применяются при реализации современных высоконагруженных и распределенных приложений, а также при реализации пользовательского интерфейса и использовании операций ввода/вывода.
Java – это один из самых популярных языков программирования, использующий асинхронность и многопоточность в частности для построения корпоративных серверных приложений, веб приложений, десктопных и мобильных приложений.
На данном курсе будет рассмотрено понятие потоков и многопоточности в целом, непосредственно концепция асинхронного программирования, а также современные приемы организации выполнения асинхронных задач на языке Java. По окончанию курса вы сможете самостоятельно создавать многопоточные и асинхронные задачи на языке Java.
Для понимания материалов данного курса потребуются знания языка Java на уровне «Java Углубленный», базовые знания Spring Framework.
По завершению данного курса вы научитесь:
- Реализовывать в своих приложениях принципы асинхронности и многопоточности для быстрой и неблокирующей работы приложения.
- Создавать и запускать потоки.
- Использовать ExecutorService и ThreadPool для управления потоками.
- Использовать Fork/Join Framework для решения проблемы с использованием параллельного подхода «разделяй и властвуй».
- Работать с потокобезопасными коллекциями.
- Использовать Future и CompletableFuture для работы с асинхронными задачами.
- Ловить и обрабатывать исключения, полученные при выполнении асинхронного кода.
- Использовать асинхронность в веб-приложениях на Spring Framework.
- Управлять выполнением задач, создавая пользовательский планировщик задач.
- Реализовывать в приложении паттерны проектирования Producer-Consumer и Scatter-Gather.
Этот курс входит в специальности:
Предварительные Требования
Java 8 (или выше), базовые знания Spring Framework.
Вы научитесь
- Создавать и запускать потоки.
- Использовать ExecutorService и ThreadPool для управления потоками.
- Использовать Fork/Join Framework для решения проблемы с использованием параллельного подхода «разделяй и властвуй».
- Работать с потокобезопасными коллекциями.
- Использовать Future и CompletableFuture для работы с асинхронными задачами.
- Ловить и обрабатывать исключения, полученные при выполнении асинхронного кода.
- Использовать асинхронность в веб-приложениях на Spring Framework.
- Управлять выполнением задач, создавая пользовательский планировщик задач
- Реализовывать паттерны проектирования Producer Consumer и Scatter-Gather.
- 4 ч 49 м
- 14.07.2021
- 10
- 14.07.2021
- русский
Что входит в курс
×
Вы действительно хотите открыть доступ к тестированию по курсу Асинхронное программирование в Java на 40 дней?
По завершению урока слушатель ознакомится с понятием многопоточного программирования, разберёт понятие потоков, их состояния, научится создавать потоки и их использовать. Также познакомится с базовыми понятиями для работы с потоками, такими как мьютекс, монитор и семафор, научится использовать ключевое слово synchronized, а также использовать семафоры для одновременного доступа к ресурсам из нескольких потоков.
Данный урок является введением в асинхронное программирование на языке Java. На уроке вы ознакомитесь с концепцией асинхронного программирования, узнаете разницу между разными концепциями многопоточного программирования. А также научитесь создавать и запускать асинхронные задачи.
На этом уроке вы узнаете, как работать с группой потоков с помощью ThreadPool. Мы создадим свою реализацию пула потоков и разберём как происходит управление жизненным циклом потоков с помощью ExecutorService. В конце урока вы узнаете о таком фреймворке как Fork/Join, зачем он нужен и научитесь его применять на практике.
На этом уроке вы познакомитесь с набором коллекций, которые более эффективно работают в многопоточной среде, нежели стандартные универсальные коллекции из java.util пакета. Будут рассмотрены реализации часто используемых коллекций. В конце урока вы сможете ознакомиться с блокирующими очередями, которые используются для работы с пулами потоков.
На этом уроке вы более подробно познакомитесь с Future API. Напомним, что мы знаем об интерфейсе Future. Вы узнаете о новом классе для работы с асинхронными задачами CompletableFuture. Узнаете в чём разница между Future и CompletableFuture. Познакомитесь с некоторыми интерфейсами с пакета java.util.function, которые активно используются в CompletableFuture., а также научитесь создавать CompletableFuture.
На этом уроке вы более подробно познакомитесь с CompletableFuture. Поработаем с методами runAsync и supplyAsync. Разберём, что такое исключение в асинхронных задачах и как с ними работать. Также будет рассмотрена обработка исключений с помощью методов exceptionally и handle.
По завершению урока слушатель ознакомится с методами thenCombine и thenCompose, которые используются для комбинирования двух независимых и зависимых задач соответственно. Так же ознакомится с методами allOf и anyOf, которые используются для объединения более чем двух задач. А также увидит, как применять эти методы на практике.
По завершению урока слушатель ознакомится с асинхронностью в веб-приложениях на Spring. На уроке рассматривается зачем и когда использовать аннотацию Async, в чем разница между асинхронным и синхронным исполнением в веб-приложении, а также как строить свои веб-приложения с использованием асинхронности.
По завершению урока слушатель ознакомится с SceduleExecutorService и научится создавать отложенные задачи с его помощью. Также изучит как использовать отложенный запуск методов в фреймворке Spring. Научится кастомизировать стандартный TaskScheduler, а также детально контролировать регистрацию задач через ScheduledTaskRegistrar.
По завершению урока слушатель ознакомится с такими паттернами проектирования как Producer Consumer и Scatter-Gather. Будет понимать, как работают различные инструменты, в основе которых лежат данные паттерны. Также ознакомится на практике с реализациями этих паттернов и сможет применять их в проектировании собственных многопоточных приложений.