Независимые процессы используют независимое множество ресурсов
Взаимодействующие процессы используют ресурсы совместно, и выполнение одного процесса может оказать влияние на результат другого.
void echo()
{
char in;
input(in)
output(in);
}
Результат выполнения процессов не должен зависеть от порядка переключения выполнения между процессами, т.е. от соотношения скорости выполнения данного процесса со скоростями выполнения других процессов
Требование мультипрограммирования
процесс 1
int semaphore; …
down(semaphore); /*критическая секция процесса 1 */ ... up(semaphore); …
процесс 2
int semaphore; …
down(semaphore); /*критическая секция процесса 2 */ ... up(semaphore); …
Структуры данных монитора доступны только для процедур, входящих в этот монитор
Процесс «входит» в монитор по вызову одной из его процедур
В любой момент времени внутри монитора может находиться не более одного процесса
think();
take_forks(i);
eat();
put_forks(i);
down(&mutex);
state[i] = HUNGRY;
test(i);
up(&mutex);
down(&s[i]);
state[i] = EATING;
up (&s[i]);
down(&mutex);
state[i] = THINKING;
test(LEFT);
test(RIGHT);
up(&mutex);
while (TRUE) {
}
down (&mutex);
rc = rc+1;
if (rc==1) down (&db);
up(&mutex);
read_data_base();
down(&mutex);
rc = rc-1;
if (rc==0) up(&db);
up(&mutex);
use_data_read();
while(TRUE) {
}
think_up_data();
down(&db);
write_data_base();
up(&db);
void barber(void)
{
}
down(customers);
down(&mutex);
waiting = wating – 1;
up(&barbers);
up(&mutex);
cut_hair();
waiting = waiting + 1;
up(&customers);
up(&mutex);
down(barbers);
get_haircut();
up(&mutex);
down(&mutex);
if (waiting < CHAIRS) {
} else {
}
Если не удалось найти и скачать презентацию, Вы можете заказать его на нашем сайте. Мы постараемся найти нужный Вам материал и отправим по электронной почте. Не стесняйтесь обращаться к нам, если у вас возникли вопросы или пожелания:
Email: Нажмите что бы посмотреть