Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекція№7_Простий безперервний розподіл і розпод...doc
Скачиваний:
1
Добавлен:
15.11.2019
Размер:
129.54 Кб
Скачать

Міністерство освіти і науки України

Горлівський технікум

Донецького національного університету

ЛЕКЦІЯ

КЕРУВАННЯ ПАМ’ЯТТЮ. ПРОСТИЙ БЕЗПЕРЕРВНИЙ РОЗПОДІЛ

І РОЗПОДІЛ З ПЕРЕКРИТТЯМ. РОЗПОДІЛ ПАМ’ЯТІ СТАТИЧНИМИ

Й ДИНАМИЧНИМИ РОЗДІЛАМИ.

з дисципліни

ОПЕРАЦІЙНІ СИСТЕМИ ТА СИСТЕМНЕ ПРОГРАМУВАННЯ

Спеціальність 5.04030101 “Прикладна математика”

Розглянута та схвалена Підготував викладач

На засіданні циклової комісії О.Л.Лотоцький

Протокол № від 2007

Голова комісії І.П.Сошина

2007

Лекція №7

Тема: Керування пам’яттю в ОС. Простий безперервний розподіл і розподіл з перекриттям. Розподіл пам’яті статичними й динамічними розділами.

План

  1. Основна пам’ять.

1.1 Вимоги до адрес, використовуваних у програмах.

  1. Поняття віртуальної пам’яті.

2.1 Проблеми реалізації віртуальної пам'яті. Фрагментація пам'яті.

2.2 Логічна і фізична адресація пам'яті.

3. Простий безперервний розподіл і розподіл з перекриттям.

3.1 Оверлейні структури.

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

4.1 Розділи з фіксованими границями.

4.2 Розділи з рухливими границями.

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

Різні види пам'яті організовані в ієрархію. На нижніх рівнях такої ієрархії пере­буває дешевша і повільніша пам'ять більшого обсягу, а в міру просування ієрархією нагору пам'ять стає дорожчою і швидшою (а її обсяг стає меншим). Найдешев­шим і найповільнішим запам'ятовувальним пристроєм є жорсткий диск комп'юте­ра. Його називають також допоміжним запам'ятовувальним пристроєм (secondary storage). Швидшою й дорожчою є оперативна пам'ять, що зберігається в мікросхемах пам’яті, встановлених на комп'ютері, - таку пам'ять називатимемо основною пам’яттю (main memory). Ще швидшими засобами зберігання даних є різні кеші процесора, а обсяг цих кешів ще обмеженіший.

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

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

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

До адрес, використовуваних у програмах, ставляться такі вимоги.

  • Захист пам'яті. Помилки в адресації, що трапляються в коді процесу, повинні впливати тільки на виконання цього процесу. Стратегія захисту пам'яті зводиться до того, що для кожного процесу зберігається діапазон коректних адрес, і кожна операція доступу до пам'яті перевіряється на приналежність адреси цьому діапазону.

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