Многопоточное программирование в Java - Тимур Машнин
Книгу Многопоточное программирование в Java - Тимур Машнин читаем онлайн бесплатно полную версию! Чтобы начать читать не надо регистрации. Напомним, что читать онлайн вы можете не только на компьютере, но и на андроид (Android), iPhone и iPad. Приятного чтения!
173 0 10:00, 03-01-2023Книга Многопоточное программирование в 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 подписчика, в котором он запрашивает еще элемент данных у издателя.
Прочитали книгу? Предлагаем вам поделится своим отзывом от прочитанного(прослушанного)! Ваш отзыв будет полезен читателям, которые еще только собираются познакомиться с произведением.
Уважаемые читатели, слушатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.
- 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
- 2. Просьба отказаться от оскорблений, угроз и запугиваний.
- 3. Просьба отказаться от нецензурной лексики.
- 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.
Надеемся на Ваше понимание и благоразумие. С уважением, администратор LoveRead.info.
Оставить комментарий
-
Анна19 июнь 19:20
Спасибо за ещё одну новиночку,так приятно и волнительно читать,особенно когда переплетается с другими историями....
Даже не сомневайся - Юлия Резник
-
Анна15 июнь 07:43
[spoiler][книга интересная,но не полная и к концу главы повторяются....
Кириленко Ирина – Бирюк
-
Вера15 июнь 01:46
Благодарю Автора!!!! Хорошо,что все хорошо кончается! Сюжет-захватывает!!!...
Звезда+1 - Алайна Салах
