Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
лекції ОС.doc
Скачиваний:
0
Добавлен:
01.05.2025
Размер:
1.02 Mб
Скачать

4.6.2. Групи процесів

При вході користувача в систему для нього створюється процес-оболонка, що є предком всіх інших процесів цього користувача. Цей процес стає лідером групи породжених їм процесів. В якості ідентифікатора групи приймається ідентифікатор (pid) її лідера. Той термінал, з якого користувач увійшов в систему, стає керуючим терміналом групи. Це може бути як локальний термінал комп'ютера, на якому працює система, так і віддалений термінал, з якого був виконаний вхід в систему по мережі.

Будь-який процес може покинути свою групу і оголосити себе лідером нової групи, до якої будуть відноситися його нащадки. Одна з груп є поточною (foreground), інші групи - фоновими (background). Процеси поточної групи можуть отримувати введення з керуючого терміналу.

Поняття групи процесів відіграє важливу роль в ряді ситуацій при роботі системи. Наприклад, якщо користувач натискає Ctrl + C, то всім процесам поточної групи посилається сигнал про необхідність завершення. При розриві з'єднання з терміналом подібний сигнал посилається всім процесам, для яких цей термінал був керуючим.

Процес може, створивши власну групу, потім «відкріпити» від керуючого терміналу. Такий процес, званий в UNIX «демоном», втрачає можливість вести діалог з користувачем, але зате він не буде завершуватися, коли користувач закінчить сеанс роботи з системою. Демони в UNIX виконують звичайно загальносистемні завдання, такі, як управління печаткою, отримання та відправка пошти, автоматичний запуск процесів в наперед задані моменти часу і т.п.

4.6.3. Програмні канали

Одним з «фірмових» винаходів UNIX, згодом запозичених іншими ОС, є поняття програмного каналу або «трубопроводу» (pipe), що дозволяє виконувати обмін даними між процесами за допомогою тих же системних викликів, які використовуються для читання / запису даних при роботі з файлами і з периферійними пристроями.

Програмні канали можуть бути безіменними або іменованими. Для створення безіменного каналу процес повинен використовувати системний виклик pipe, яка повертає масив з двох елементів, що

містять хендл для читання з каналу і хендл для запису в канал. Після цього для роботи з каналом можна використовувати звичайні функції читання з файлу і запису у файл, вказуючи відповідні хендл каналу. Як правило, процес, який створив канал, потім породжує двох нащадків, з яких один буде виконувати запис в канал, а інший - читання (нагадаємо, що при створенні процесу він отримує копії всіх хендл, відкритих батьком). Не виключена також можливість використання каналу декількома процесами, кожен з яких може, в принципі, як записувати, так і читати дані.

Дані, записувані в канал, буферизуются системою в пам'яті і потім можуть бути прочитані функціями читання з каналу. Якщо в каналі немає даних, то функція читання блокує викликав її процес, поки інший процес не запише дані в канал.

Якщо всі процеси закрили хендл записи в канал (тобто, немає шансів, що в канал будуть поміщені ще які-небудь дані), то процес-читач, вибравши всі дані, які ще залишалися в каналі, прочитає потім ознака кінця файлу.

Гірше, якщо закриті всі хендл читання, а який-небудь процес намагається виконати запис даних, які нікому буде прочитати. У цьому випадку система посилає процесу сигнал про помилку роботи з каналом.

Використання безіменних каналів має одне обмеження: всі процеси, що працюють з каналом, повинні бути нащадками процесу, який створив канал. Для передачі даних між неспорідненими процесами можна використовувати іменовані канали, звані також каналами FIFO. Такий канал створюється системним викликом mknod, при цьому вказується шлях і ім'я каналу, як при створенні файлу. Імена каналів зберігаються в каталогах файлової системи UNIX нарівні з іменами звичайних і спеціальних файлів. Щоб відкрити канал для читання або для запису, використовується звичайний системний виклик open із зазначенням необхідного режиму доступу, як при відкритті файлу.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]