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

Взаємодія потоків.Програмний інтерфейс взаємодії WinАрі.

Функції очікування

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

У разі невиконання умови сигналізації потік переходить у стан очікування, витрачаючи дуже мало ресурсів, доти поки сигналізація всетаки не відбудеться або поки не мине максимальний час очікування, якщо він був заданий. Для очікування сигналізації одного об’єкта у WIN32 використовують уже знайому функцію Waitforsingleobject()

Мютекси

Найпростішим синхронізаційними об’єктами із дескрипторами є мютекси. Для створення мютекса використовують функцію CreateMutex();

Імя мютекса задавати не обов’язково якщо потрібно звертатися до мютекса тільки у рамках цього процесу.

Коли мютекс зайнятий то поточний потік очікує поки його не буде звільнено. У першому він блокує мютекс у другому ні.Звільнення мютексу здійснює функція releasemutex(mutex).вони є рекурсивними.

Події засоби сигналізації об’єктів для виклику деяких дій відповіддю на події звичайно є поновлення одного або кількох потоків. Фактично події можна розуміти як спробу реалізувати функціональність умовних зиінних без інтеграції з мютексом.

3 Функціональні компоненти операційних систем

Операційну систему можна розглядати як сукупність функціональних компонен-

тів, кожен з яких відповідає за реалізацію певної функції системи. У цьому розділі

описані найважливіші функції сучасних ОС і компоненти, що їх реалізують.

Спосіб побудови системи зі складових частин та їхній взаємозв'язок визначає

архітектура операційної системи. Підходи до реалізації архітектури ОС будуть

розглянуті в розділі 2.

Білет №23

Взаємодія з диском підчас керування пам'яттю. Годинниковий алгоритм.

Годинниковий алгоритм.

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

Спочатку беруть сторінку, що найдовше перебуває у пам'яті (як для FIFO). Якщо її біт використання (R) дорівнює 0, то сторінку негайно замінюють, помі-

щаючи на її місце нову. Якщо ж біт R дорівнює 1 (до сторінки зверталися), то

його покладають рівним 0 (начебто ця сторінка тільки що завантажена у пам'ять), і прохід за списком триває далі, поки не буде знайдена сторінка з R =

0 (а доти біт R для всіх сторінок покладають рівним 0). Знайдену сторінку замінюють, після чого для нової сторінки задають R = 1 і наставляють на неї стрілку (рис. 9.6). У найгіршому випадку (якщо для всіх сторінок біт R дорівнює одиниці) почнеться друге коло обходу списку (другий шанс) і буде замінена найстарша сторінка із тих, що були пройдені на першому колі. У цьому разі алгоритм зводиться до алгоритму FIFO.

Взаємодія потоків.Взаємодія потоків у Linux.

Взаємодія потоків у Linux

Бібліотеки підтримки потоків Linux (LinuxThreads і NPTL) надають програмам

користувача набір синхронізаційних примітивів, визначених стандартом POSIX

(м'ютекси, умовні змінні, семафори, блокування читання-записування, бар'єри).

Крім того, у NPTL допускають використання цих примітивів у поєднанні з відображуваноюабо розподілюваною пам'яттю для реалізації міжпроцесової синхронізації.Описані примітиви реалізовані на основі базових механізмів синхронізації,доступних через системні виклики (у ядрі версії 2.6 до них належать ф'ютекси).Крім того, код ядра може використовувати спеціальні механізми синхронізації,доступні тільки у ядрі.Далі розглянемо базові механізми синхронізації ядра і застосувань користувача.

Механізми синхронізації ядра Linux

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

Аналогом потоків у ядрі виступають шляхи передачі керування ядра (kernel

control paths). Таким шляхом є послідовність інструкцій, виконуваних ядром дляреалізації реакції на системний виклик або обробку переривання. Така послідовністьзвичайно зводиться до виконання кількох функцій ядра. Наприклад, дляобробки системного виклику шлях передачі керування починають з виклику функціїsystem_cal ІО і завершують викликом ret_system_call О. Надалі іноді говоритимемоне про шляхи керування, а про процеси в режимі ядра, маючи на увазі шляхипередачі керування, що відповідають системним викликам, виконаним процесами.

3.Динамічний розподіл пам'яті. Системи двійників.

Системи двійників

(buddy system), – підхід до динамічного розподілу пам'яті, який дає змогу рідше розбивати на частини більші блоки для виділення пам'яті під блоки меншого розміру, знижуючи цим зовнішню фрагментацію. Вона містить у собі

два алгоритми: виділення та вивільнення пам'яті. Розглянемо найпростішу бінарну систему двійників (binary buddy system).

У разі використання найпростішої бінарної системи двійників (binary buddy

system) пам'ять розбивають на блоки, розмір яких є степенем числа 2: 2K, LKU, де 2L – мінімальний розмір блоку; 2U — максимальний розмір блоку (він може бути розміром доступної пам'яті, а може бути й меншим).

Білет №24

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