Студопедия — Алгоритмы реализации взаимоисключений
Студопедия Главная Случайная страница Обратная связь

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

Алгоритмы реализации взаимоисключений






Алгоритм:

Блокирующая глобальная переменная(замок):

shared int lock = 0; // замок открыт

process1

while (lock); // пролог

//Если тут прерывания, то произойдет ппц. Сюда может зайти второй и тогда оба могу зайти в //к.р.

lock = 1; // пролог

{к.с.}

locl = 0; // эпилог

Строгое чередование:

shared int turn = 0;

process I

while(turn!= I);

{к.с.}

turn = 1-i;

если 1 из процессов не выполняет свою секцию, то он не отдаст второму.

Алгоритм флагов готовности:

shared int ready[2]={0,0};

process I

ready[i]=1;

Прерывание оба процесса тут. Оба подняли флаги, тогда оба насмерть вешаются(взаим.блок).

while (ready[1-i]);

{к.с.}

ready[i]=0;

Алгоритм Пэтерсона (взаимной вежливости):

shared int ready[2]= {0,0}

shared int turn;

process I

ready[i]=1;

turn = 1 – I;

while(ready[1-i] && turn == 1- I)

{к.с.}

ready[i]=0;

Проблема появляется, когда много процессов, много проверок будет. Большое время разрешения коллизий. Эффективен для малого количества процессов.

 

Среди ресурсов ОС существуют такие, которые могут быть использованы только одним процессом.

Лучшее решение: блокировать только в момент, когда коду требуется обратиться к такому ресурсу. Такая секции кода называется критической секцией. В таком случае в стеке команд у процесса будет: пролог{ крит секция } эпилог. В момент входа и выхода в крит секцию требуется объявлять об этом системе.

Методы решения проблем взаимоблокировки:

1. однопрограммное выполнение. В прологе блокируются выполнение любых процессов с этими данными. В unix – psw используется для обновления pcb

2. блокирующая глобальна переменная (мьютекс/замок). При не атомарности между while и lock = 1, возникает одновременное использование крит секции.

shared int lock = 0;

процесс 1

while (lock);

lock = 1;

{крит секция}

lock = 0;

3. алгоритм строго чередовании (семафор) Недостаток – передача управлении над критической секцией когда другому процессу она не нужна.

i = 0 или 1;

shared int turn = 0;

процесс i:

while (turn!= i);

{крит секция}

turn = 1-i;

4. Алгоритм флагов готовности. Недостаток: при прерывание между ready[i] и while(ready[1-i]) возникает взаимоблокрировка.

shared int ready[2] = {0, 0};

процесс i:

ready[i] = 1;

while (ready[1-i]);

{ крит секция}

ready [i] = 0;

 

23. Семафоры Дейкстра. Решение проблемы «производитель-потребитель» с помощью семафоров.

Семафор (S) – целочисленная переменная >=0

p(S): пока S == 0 – блокировать процесс; S--; (атомарная операция)

v(S): S++ (атомарная операция)

 

Модель работы:

Producer ->buffer[n] -> Consumer; если буфер не полный – producer отправляет туда данные, иначе ждет. Consumer читает данные если есть, иначе ждет.

 

Объявим 3 семафора.

1. mutex = 1 (0 или 1)

2. empty = N (количество свободных мест в буфере)

3. full = 0 (сколько байт занято в буфере)

Producer:

while (true)

{

produce_item();

p(empty);

p(mutex)

put_item();

v(mutex);

v(full);

}

 

Consumer:

while (true)

{

p(full)

p(mutex)

get_item()

v(mutex)

v(empty)

consume_item()

}

 







Дата добавления: 2015-04-19; просмотров: 1064. Нарушение авторских прав; Мы поможем в написании вашей работы!



Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...

Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...

Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...

Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

Особенности массовой коммуникации Развитие средств связи и информации привело к возникновению явления массовой коммуникации...

Тема: Изучение приспособленности организмов к среде обитания Цель:выяснить механизм образования приспособлений к среде обитания и их относительный характер, сделать вывод о том, что приспособленность – результат действия естественного отбора...

Тема: Изучение фенотипов местных сортов растений Цель: расширить знания о задачах современной селекции. Оборудование:пакетики семян различных сортов томатов...

ТРАНСПОРТНАЯ ИММОБИЛИЗАЦИЯ   Под транспортной иммобилизацией понимают мероприятия, направленные на обеспечение покоя в поврежденном участке тела и близлежащих к нему суставах на период перевозки пострадавшего в лечебное учреждение...

Кишечный шов (Ламбера, Альберта, Шмидена, Матешука) Кишечный шов– это способ соединения кишечной стенки. В основе кишечного шва лежит принцип футлярного строения кишечной стенки...

Принципы резекции желудка по типу Бильрот 1, Бильрот 2; операция Гофмейстера-Финстерера. Гастрэктомия Резекция желудка – удаление части желудка: а) дистальная – удаляют 2/3 желудка б) проксимальная – удаляют 95% желудка. Показания...

Studopedia.info - Студопедия - 2014-2024 год . (0.037 сек.) русская версия | украинская версия