Читать книгу - "Многопоточное программирование в Java - Тимур Машнин"
Аннотация к книге "Многопоточное программирование в Java - Тимур Машнин", которую можно читать онлайн бесплатно без регистрации
В многопроцессорных системах многопоточность решает проблему параллельного выполнения кода с наименьшими затратами. Поэтому многопоточность используется в большинстве реальных приложений. И Java, как и большинство языков программирования, поддерживает многопоточность. Познакомьтесь с реализацией процессов и потоков в Java, с управлением и синхронизацией потоков. Узнайте о пуле потоков, потокобезопасных коллекциях, синхронизаторах и параллельных потоках Stream.
Это интерфейс Publisher — производитель элементов данных, получаемых подписчиками.
Интерфейс Subscriber — приемник элементов данных.
Интерфейс Subscription — связь между издателем и подписчиком.
И интерфейс Processor — комбинация Publisher и Subscriber для преобразования данных.
Издатель публикует поток данных для зарегистрированных подписчиков и реализует интерфейс Flow. Publisher.
Этот интерфейс объявляет единственный метод, который вызывается для регистрации подписчика у издателя.
Вызов этого метода регистрирует подписчика у издателя.
Однако, если подписчик уже зарегистрирован или регистрация терпит неудачу, этот метод вызывает метод onError подписчика с объектом IllegalStateException.
При удачной подписке вызывается метод onSubscribe подписчика с новым объектом Flow.Subscription.
Подписчик подписывается на издателя для получения элементов данных и реализует интерфейс Flow.Subscriber.
Этот интерфейс объявляет метод onSubscribe и три дополнительных метода.
Метод onSubscribe вызывается для подтверждения регистрации.
Он получает в качестве аргумента подписку, методы которой позволяют запрашивать новые элементы данных у издателя или запрашивать, чтобы издатель больше не отправлял элементы данных.
Метод onComplete вызывается, когда издатель закрывает подписку.
Метод onError вызывается при возникновении ошибки в процессе подписки.
Метод onNext вызывается, когда издатель публикует элемент данных.
Подписка обеспечивает связь между издателем и подписчиком, позволяя подписчикам получать данные только по запросу и позволяя отменить подписку в любое время.
Подписка реализует интерфейс Flow.Subscription, который объявляет два метода.
Метод request добавляет n элементов данных к текущему невыполненному требованию для этой подписки.
Если n меньше или равно 0, метод onError подписчика вызывается с аргументом IllegalArgumentException.
В противном случае подписчик получает до n дополнительных вызовов метода onNext.
Передача в качестве аргумента значения Long.MAX_VALUE указывает неограниченное количество вызовов.
Метод cancel отменяет подписку. Но дополнительные элементы данных могут быть получены после вызова метода cancel.
Наконец, процессор представляет собой функцию преобразования данных, которая работает в потоке.
Один или несколько процессоров могут быть размещены между издателем и подписчиком для преобразования одного потока данных в другой.
Класс SubmissionPublisher реализует интерфейс Flow. Publisher, асинхронно выдавая ненулевые элементы данных текущим подписчикам до тех пор, пока подписка не будет закрыта.
Каждый текущий подписчик получает вновь представленные элементы данных в том же порядке, что и их публикация, если они не будут утеряны или не будет выброшено исключение.
SubmissionPublisher предоставляет три конструктора для инициализации издателя.
Простейший конструктор без аргументов создает издателя, который использует метод ForkJoinPool.commonPool, чтобы обеспечить асинхронность, необходимую для доставки элементов данных подписчикам.
Здесь мы создаем объект SubmissionPublisher издателя и регистрируем для него подписчика MySubscriber.
Затем издатель в строковом потоке публикует элементы потока.
После чего издатель закрывает подписку.
Подписчик MySubscriber реализует интерфейс Subscriber.
В методе подписки onSubscribe он запрашивает элемент данных у издателя.
Когда издатель публикует элемент данных, вызывается метод onNext подписчика, в котором он запрашивает еще элемент данных у издателя.
Прочитали книгу? Предлагаем вам поделится своим впечатлением! Ваш отзыв будет полезен читателям, которые еще только собираются познакомиться с произведением.
Оставить комментарий
-
Илья12 январь 15:30
Книга прекрасная особенно потому что Ее дали в полном виде а не в отрывке
Горький пепел - Ирина Котова
-
Гость Алексей04 январь 19:45
По фрагменту нечего комментировать.
Бригадный генерал. Плацдарм для одиночки - Макс Глебов
-
Гость галина01 январь 18:22
Очень интересная книга. Читаю с удовольствием, не отрываясь. Спасибо! А где продолжение? Интересно же знать, а что дальше?
Чужой мир 3. Игры с хищниками - Альбер Торш
-
Олена кам22 декабрь 06:54
Слушаю по порядку эту серию книг про Дашу Васильеву. Мне очень нравится. Но вот уже третий день захожу, нажимаю на треугольник и ничего не происходит. Не включается
Донцова Дарья - Дантисты тоже плачут


