Sistem Operasi - Manajemen Memori

Manajemen memori adalah fungsionalitas sistem operasi yang menangani atau mengelola memori utama dan memindahkan proses bolak-balik antara memori utama dan disk selama eksekusi. Manajemen memori melacak setiap lokasi memori, terlepas dari apakah itu dialokasikan untuk beberapa proses atau gratis. Ia memeriksa berapa banyak memori yang akan dialokasikan untuk proses. Ini memutuskan proses mana yang akan mendapatkan memori pada jam berapa. Ini melacak setiap kali beberapa memori dibebaskan atau tidak dialokasikan dan karenanya memperbarui status.

Tutorial ini akan mengajarkan Anda konsep dasar yang berkaitan dengan Manajemen Memori.

Ruang Alamat Proses

Ruang alamat proses adalah sekumpulan alamat logis yang direferensikan oleh proses dalam kodenya. Misalnya, saat pengalamatan 32-bit digunakan, alamat dapat berkisar dari 0 hingga 0x7fffffff; yaitu, 2 ^ 31 kemungkinan angka, dengan ukuran teoretis total 2 gigabyte.

Sistem operasi menangani pemetaan alamat logis ke alamat fisik pada saat alokasi memori ke program. Ada tiga jenis alamat yang digunakan dalam program sebelum dan sesudah memori dialokasikan -

SN Alamat & Deskripsi Memori
1

Symbolic addresses

Alamat yang digunakan dalam kode sumber. Nama variabel, konstanta, dan label instruksi adalah elemen dasar dari ruang alamat simbolik.

2

Relative addresses

Pada saat kompilasi, kompilator mengubah alamat simbolik menjadi alamat relatif.

3

Physical addresses

Loader menghasilkan alamat ini pada saat program dimuat ke memori utama.

Alamat virtual dan fisik sama dalam skema pengikatan alamat waktu kompilasi dan waktu muat. Alamat virtual dan fisik berbeda dalam skema pengikatan alamat waktu eksekusi.

Himpunan semua alamat logis yang dihasilkan oleh program disebut sebagai a logical address space. Himpunan semua alamat fisik yang sesuai dengan alamat logis ini disebut sebagaiphysical address space.

Pemetaan runtime dari alamat virtual ke fisik dilakukan oleh unit manajemen memori (MMU) yang merupakan perangkat keras. MMU menggunakan mekanisme berikut untuk mengubah alamat virtual ke alamat fisik.

  • Nilai dalam register dasar ditambahkan ke setiap alamat yang dihasilkan oleh proses pengguna, yang diperlakukan sebagai offset pada saat dikirim ke memori. Misalnya, jika nilai register dasar adalah 10000, maka upaya pengguna untuk menggunakan lokasi alamat 100 akan dialokasikan kembali secara dinamis ke lokasi 10100.

  • Program pengguna berhubungan dengan alamat virtual; itu tidak pernah melihat alamat fisik yang sebenarnya.

Pemuatan Statis vs Dinamis

Pilihan antara Static atau Dynamic Loading dibuat pada saat program komputer sedang dikembangkan. Jika Anda harus memuat program Anda secara statis, maka pada saat kompilasi, program lengkap akan dikompilasi dan ditautkan tanpa meninggalkan program eksternal atau ketergantungan modul. Linker menggabungkan program objek dengan modul objek lain yang diperlukan menjadi program absolut, yang juga menyertakan alamat logis.

Jika Anda menulis program yang dimuat secara dinamis, maka kompiler Anda akan mengkompilasi program tersebut dan untuk semua modul yang ingin Anda sertakan secara dinamis, hanya referensi yang akan disediakan dan pekerjaan lainnya akan diselesaikan pada saat eksekusi.

Pada saat memuat, dengan static loading, program absolut (dan data) dimuat ke dalam memori agar eksekusi dapat dimulai.

Jika Anda menggunakan dynamic loading, rutinitas dinamis dari pustaka disimpan pada disk dalam bentuk yang dapat direlokasi dan dimuat ke dalam memori hanya ketika dibutuhkan oleh program.

Penautan Statis vs Dinamis

Seperti yang dijelaskan di atas, saat penautan statis digunakan, penaut menggabungkan semua modul lain yang diperlukan oleh program menjadi satu program yang dapat dijalankan untuk menghindari ketergantungan waktu proses.

Ketika penautan dinamis digunakan, tidak diperlukan untuk menautkan modul atau pustaka yang sebenarnya dengan program, melainkan referensi ke modul dinamis disediakan pada saat kompilasi dan penautan. Perpustakaan Tautan Dinamis (DLL) di Windows dan Objek Bersama di Unix adalah contoh bagus dari perpustakaan dinamis.

Swapping

Swapping adalah mekanisme di mana suatu proses dapat ditukar sementara dari memori utama (atau dipindahkan) ke penyimpanan sekunder (disk) dan membuat memori tersebut tersedia untuk proses lain. Di lain waktu, sistem menukar kembali proses dari penyimpanan sekunder ke memori utama.

Meskipun kinerja biasanya dipengaruhi oleh proses swapping tetapi itu membantu dalam menjalankan banyak proses besar secara paralel dan itulah alasannya Swapping is also known as a technique for memory compaction.

Total waktu yang dibutuhkan oleh proses swapping termasuk waktu yang diperlukan untuk memindahkan seluruh proses ke disk sekunder dan kemudian menyalin proses tersebut kembali ke memori, serta waktu yang dibutuhkan untuk mendapatkan kembali memori utama.

Mari kita asumsikan bahwa proses pengguna berukuran 2048KB dan pada hard disk standar tempat pertukaran akan berlangsung memiliki kecepatan transfer data sekitar 1 MB per detik. Transfer sebenarnya dari proses 1000K ke atau dari memori akan membutuhkan

2048KB / 1024KB per second
= 2 seconds
= 2000 milliseconds

Sekarang mempertimbangkan waktu masuk dan keluar, ini akan membutuhkan 4000 milidetik ditambah overhead lainnya di mana proses bersaing untuk mendapatkan kembali memori utama.

Alokasi memori

Memori utama biasanya memiliki dua partisi -

  • Low Memory - Sistem operasi berada di memori ini.

  • High Memory - Proses pengguna disimpan dalam memori tinggi.

Sistem operasi menggunakan mekanisme alokasi memori berikut.

SN Alokasi & Deskripsi Memori
1

Single-partition allocation

Dalam jenis alokasi ini, skema register relokasi digunakan untuk melindungi proses pengguna dari satu sama lain, dan dari mengubah kode dan data sistem operasi. Register relokasi berisi nilai alamat fisik terkecil sedangkan register batas berisi kisaran alamat logis. Setiap alamat logis harus kurang dari register batas.

2

Multiple-partition allocation

Dalam jenis alokasi ini, memori utama dibagi menjadi beberapa partisi berukuran tetap di mana setiap partisi hanya berisi satu proses. Ketika sebuah partisi kosong, sebuah proses dipilih dari antrian input dan dimuat ke partisi gratis. Ketika proses berakhir, partisi menjadi tersedia untuk proses lain.

Fragmentasi

Saat proses dimuat dan dihapus dari memori, ruang memori bebas dipecah menjadi potongan-potongan kecil. Itu terjadi setelah terkadang proses tidak dapat dialokasikan ke blok memori mengingat ukurannya yang kecil dan blok memori tetap tidak digunakan. Masalah ini dikenal sebagai Fragmentasi.

Fragmentasi terdiri dari dua jenis -

SN Fragmentasi & Deskripsi
1

External fragmentation

Ruang memori total cukup untuk memenuhi permintaan atau untuk menyimpan proses di dalamnya, tetapi tidak bersebelahan, sehingga tidak dapat digunakan.

2

Internal fragmentation

Blok memori yang ditugaskan untuk memproses lebih besar. Beberapa bagian dari memori tidak digunakan, karena tidak dapat digunakan oleh proses lain.

Diagram berikut menunjukkan bagaimana fragmentasi dapat menyebabkan pemborosan memori dan teknik pemadatan dapat digunakan untuk membuat lebih banyak memori bebas dari memori terfragmentasi -

Fragmentasi eksternal dapat dikurangi dengan pemadatan atau pengacakan konten memori untuk menempatkan semua memori bebas bersama dalam satu blok besar. Untuk membuat pemadatan memungkinkan, relokasi harus dinamis.

Fragmentasi internal dapat dikurangi dengan secara efektif menetapkan partisi terkecil tetapi cukup besar untuk proses tersebut.

Paging

Komputer dapat menangani lebih banyak memori daripada jumlah yang terpasang secara fisik pada sistem. Memori ekstra ini sebenarnya disebut memori virtual dan ini adalah bagian dari hard yang diatur untuk meniru RAM komputer. Teknik paging berperan penting dalam mengimplementasikan memori virtual.

Paging adalah teknik manajemen memori di mana ruang alamat proses dipecah menjadi blok berukuran sama yang disebut pages(ukuran pangkat 2, antara 512 byte dan 8192 byte). Ukuran proses diukur dalam jumlah halaman.

Demikian pula, memori utama dibagi menjadi blok berukuran tetap kecil yang disebut memori (fisik) frames dan ukuran bingkai dipertahankan sama dengan ukuran halaman untuk mendapatkan pemanfaatan memori utama yang optimal dan untuk menghindari fragmentasi eksternal.

Terjemahan Alamat

Alamat halaman dipanggil logical address dan diwakili oleh page number dan offset.

Logical Address = Page number + page offset

Alamat bingkai dipanggil physical address dan diwakili oleh a frame number dan offset.

Physical Address = Frame number + page offset

Sebuah struktur data disebut page map table digunakan untuk melacak hubungan antara halaman dari suatu proses ke bingkai dalam memori fisik.

Ketika sistem mengalokasikan bingkai ke halaman mana pun, itu menerjemahkan alamat logis ini ke alamat fisik dan membuat entri ke tabel halaman untuk digunakan selama pelaksanaan program.

Ketika suatu proses akan dieksekusi, halaman terkait dimuat ke dalam frame memori yang tersedia. Misalkan Anda memiliki program sebesar 8Kb tetapi memori Anda hanya dapat menampung 5Kb pada suatu titik waktu tertentu, maka konsep paging akan muncul. Ketika komputer kehabisan RAM, sistem operasi (OS) akan memindahkan halaman memori yang tidak aktif atau tidak diinginkan ke memori sekunder untuk membebaskan RAM untuk proses lain dan mengembalikannya saat dibutuhkan oleh program.

Proses ini berlanjut selama seluruh eksekusi program di mana OS terus menghapus halaman idle dari memori utama dan menulisnya ke memori sekunder dan mengembalikannya saat diperlukan oleh program.

Keuntungan dan Kerugian Paging

Berikut adalah daftar keuntungan dan kerugian paging -

  • Paging mengurangi fragmentasi eksternal, tetapi masih mengalami fragmentasi internal.

  • Paging mudah diimplementasikan dan diasumsikan sebagai teknik manajemen memori yang efisien.

  • Karena ukuran halaman dan bingkai sama, pertukaran menjadi sangat mudah.

  • Tabel halaman membutuhkan ruang memori ekstra, jadi mungkin tidak baik untuk sistem yang memiliki RAM kecil.

Segmentasi

Segmentasi adalah teknik manajemen memori di mana setiap pekerjaan dibagi menjadi beberapa segmen dengan ukuran berbeda, satu untuk setiap modul yang berisi bagian yang menjalankan fungsi terkait. Setiap segmen sebenarnya adalah ruang alamat logis yang berbeda dari program tersebut.

Ketika suatu proses akan dieksekusi, segmentasinya yang sesuai dimuat ke dalam memori yang tidak bersebelahan meskipun setiap segmen dimuat ke dalam blok memori yang tersedia yang berdekatan.

Manajemen memori segmen bekerja sangat mirip dengan paging tetapi di sini segmen memiliki panjang variabel dimana seperti pada halaman halaman memiliki ukuran tetap.

Segmen program berisi fungsi utama program, fungsi utilitas, struktur data, dan sebagainya. Sistem operasi memelihara asegment map tableuntuk setiap proses dan daftar blok memori bebas bersama dengan nomor segmen, ukurannya dan lokasi memori yang sesuai di memori utama. Untuk setiap segmen, tabel menyimpan alamat awal segmen dan panjang segmen. Referensi ke lokasi memori mencakup nilai yang mengidentifikasi segmen dan offset.