Студопедия
Случайная страница | ТОМ-1 | ТОМ-2 | ТОМ-3
АрхитектураБиологияГеографияДругоеИностранные языки
ИнформатикаИсторияКультураЛитератураМатематика
МедицинаМеханикаОбразованиеОхрана трудаПедагогика
ПолитикаПравоПрограммированиеПсихологияРелигия
СоциологияСпортСтроительствоФизикаФилософия
ФинансыХимияЭкологияЭкономикаЭлектроника

Блокировки нитей

Демонстрационный пример | Как организовать нить | С нитями выполнения нужно быть осторожным | Завершение и останов нити | Интерфейс Runable | Диспетчеризация нитей | Конкурентный доступ к ресурсам при многопоточной обработке | Демонстрационный пример | Средства синхронизации нитей в Java | За все приходится платить |


Читайте также:
  1. Quot; С ….. ч …. мин по ….. путиперегона …… действие блокировкизакрывается и устанавливается движениепоездов по телефонной связи по правиламоднопутного движения".
  2. Блокировки, разрешающие пуск ТПН (открытие СК)
  3. ДВИЖЕНИЕ ПОЕЗДОВ ПРИ НЕИСПРАВНОСТИ ПОЛУАВТОМАТИЧЕСКОЙ БЛОКИРОВКИ
  4. Диспетчеризация нитей
  5. Перечислите неисправности автоблокировки, при которых необходимо прекращать ее действие. Что является разрешением на занятие перегона в этом случае.
  6. ПОРЯДОК ДЕЙСТВИЙ ПРИ НЕИСПРАВНОСТЯХ АВТОБЛОКИРОВКИ

Продолжим рассмотрение конкурентного доступа нитей к ресурсам и сосредоточим свое внимание на блокировках нитей.

Когда одна из нитей входит в критический участок (synchronized метод или блок), связанный с блокировкой какого-то объекта, то остальные нити не могут войти в критические участки, связанные с блокировкой того-же объекта, пока захватившая объект нить не выйдет из критического участка. Т.е. блокировка объекта может вызывать блокировку ряда нитей.

Кроме этого варианта, мы рассмотрели еще один способ блокировки процесса на некоторое время — это метод sleep, который блокирует нить на некоторое время.

В Java есть еще две возможности заблокировать нить — это вызвать операцию ввода/вывода и вызвать метод wait.

Заблокированные нити не участвуют в конкурентоной борьбе за время процессора. Планировщик (sheduler), выделяющий кванты времени нитям, просто игнорирует их. В отличии от заблокированных нитей, нити, которые участвуют в конкурентной борьбе за процессор, мы будем называть активнымиrunable (более точный перевод — готовые к выполнению). Ну и для полноты терминологии, ту нить (или нити, если на машине несколько процессоров), которая выпоняется в настоящее время мы будем называть выполняющейся.

Суммируя, можно сказать, что нить может быть заблокирована в следующих случаях.


Дата добавления: 2015-08-18; просмотров: 72 | Нарушение авторских прав


<== предыдущая страница | следующая страница ==>
Исправленный пример| Метод wait

mybiblioteka.su - 2015-2024 год. (0.007 сек.)