КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Динамическое избежание взаимоблокировок
В этом способе ОС должна знать, является ли предоставление ресурса безопасным или нет.
Траектории ресурсов Рассмотрим модель из двух процессов и двух ресурсов. А1 - запрос принтера процессом А А2 - запрос плоттера процессом А А3 - освобождение принтера процессом А А4 - освобождение плоттера процессом А В1 - запрос плоттера процессом В В2 - запрос принтера процессом В В3 - освобождение плоттера процессом В В4 - освобождение принтера процессом В Динамическое избежание взаимоблокировок
Т.к. процессор предоставляется поочередно, траектория может продолжаться только параллельно осям. Чтобы избежать тупика, процессам надо обойти прямоугольник, охватывающий всю заштрихованную область.
Безопасные и небезопасные состояния В безопасном состоянии система может гарантировать, что все процессы закончат свою работу. Рассмотрим систему. 10 экземпляров ресурса 3 процесса
Процесс А занял 3 экземпляра, но ему необходимо 9. В этой ситуации можно спланировать так, сначала запустить процесс В, потом С и потом А. Процессы заканчивают работу без тупиковой ситуации.
Рассмотрим другую ситуацию. Процесс А занял 4 экземпляра. Возникает небезопасное состояние. В принципе, процесс А может в какой то момент ресурс освободить и тупика не возникнет. Видно, что в этом случае не стоило давать ресурс процессу А.
Алгоритм банкира для одного вида ресурсов "Банкира", потому что аналогия такая, клиенты-процессы, кредиты-ресурсы. Рассмотрим систему: Банкир может дать 10 кредитов (ресурсы). К нему попеременно обращаются 4-ре клиента. Алгоритм банкира: 1. Банкиру поступает запрос от клиента на получение кредита 2. Банкир проверяет, приводит ли этот запрос к небезопасному состоянию. 3. Банкир в зависимости от этого дает или отказывает в кредите. Алгоритм банкира
Алгоритм банкира для несколько видов ресурсов
Рассмотрим систему: вектора:
Алгоритм поиска безопасного или небезопасного состояния:
Алгоритм банкира для несколько видов ресурсов
Если состояние безопасное то ресурс дать можно, если нет то нельзя. На практике все эти алгоритмы тяжело реализовать.
Дата добавления: 2014-01-06; Просмотров: 378; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |