Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
lektsiya_10.docx
Скачиваний:
11
Добавлен:
05.09.2019
Размер:
2 Mб
Скачать

10.2. Розподіл пам'яті без використання дискового простору

10.2.1. Розподіл пам'яті фіксованими розділами

Найпростішим способом управління оперативною пам'яттю є поділ її на області з фіксованими кордонами. Це може бути виконано під час генерації ОС. У тому випадку, коли розділи мають однаковий розмір, розміщення процесів в пам'яті представляє собою тривіальну задачу. Не має значення, в якому з вільних розділів буде розміщений процес. Але при цьому підході є і свої труднощі:

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

2. Використання пам'яті при цьому вкрай неефективно. Так, маленька програма все одно буде займати цілком весь розділ, при цьому залишається невикористана пам'ять. Цей феномен невикористаної пам'яті називається внутрішньою фрагментацією.

Коли розділи мають різні розміри, чергове завдання, що надійшла на виконання, міститься або в загальну чергу (рисунок 10.3, а), або в чергу до деякого розділу (рисунок 10.3, б). Підсистема управління пам'яттю в цьому випадку виконує наступні задачі:

- Порівнюючи розмір програми, що надійшла на виконання, і вільних розділів, вибирає відповідний розділ;

- Здійснює завантаження програми і настроювання адрес.

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

Рис. 10.3. Розподіл пам'яті фіксованими розділами:

а) - із загальною чергою; б) - з окремими чергами для кожного розділу

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

Фіксоване розподіл в даний час практично не використовується. Прикладом ОС з використанням даної технології може служити рання ОС IBM для мейнфреймів OS / MFT (Multiprogramming with a Fixed number of Tasks - багатозадачна з фіксованою кількістю задач).

10.2.2. Динамічний розподіл пам'яті

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

Так в момент t0 у пам'яті знаходиться тільки ОС, а до моменту t1 пам'ять розділена між 5 задачами, причому задача П4, завершуючись, залишає пам'ять. На звільнене після задачі П4 місце завантажується задача П6, що надійшла в момент t3.

Завданнями ОС при реалізації даного методу керування пам'яттю є:

- Ведення таблиць вільних і зайнятих областей, в яких вказуються початкові адреси і розміри ділянок пам'яті;

- При надходженні нової задачі - аналіз запиту, перегляд таблиці вільних областей і вибір розділу, розмір якого достатній для розміщення надійшла завдання;

- Завантаження завдання у виділений їй розділ і коректування таблиць вільних і зайнятих областей;

- Після завершення завдання коректування таблиць вільних і зайнятих областей.

Програмний код не переміщається під час виконання, тобто може бути проведена одноразова настройка адрес, за допомогою використання переміщує завантажувача.

Рис. 10.4. Розподіл пам'яті динамічними розділами

Вибір розділу для нової задачі може здійснюватися за різними правилами, таким, наприклад, як "перший-ліпший розділ достатнього розміру", або "розділ, що має найменший достатній розмір". Всі ці правила мають свої переваги і недоліки.

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

Свого часу динамічний розподіл використовувала ОС IBM для мейнфреймів OS / MVT (Multiprogramming with a Variable number of Tasks - багатозадачна зі змінною кількістю завдань).

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