wisemonkeys logo
FeedNotificationProfileManage Forms
FeedNotificationSearchSign in
wisemonkeys logo

Blogs

Memory Partitioning

profile
Prachi Bharadwa FY IT
Aug 14, 2024
0 Likes
0 Discussions
460 Reads

Memory partitioning in an operating system (OS) is a technique used to manage memory allocation by dividing the system's physical memory into distinct regions, or partitions. Each partition can be allocated to processes or the operating system itself. Memory partitioning is crucial for optimizing memory utilization and ensuring that multiple processes can run efficiently without interfering with each other. There are several memory partitioning schemes, and each has its advantages and disadvantages. Here's a detailed explanation of the key concepts:


1. Fixed Partitioning Definition: In fixed partitioning, the memory is divided into a fixed number of partitions at system startup. The size and number of partitions are predefined.

• Advantages: 

Simple to implement. 

Low overhead for partition management.

• Disadvantages: 

Inefficient use of memory because a process may be allocated a partition larger than its actual needs (internal fragmentation).

The number of partitions limits the number of processes that can be loaded into memory simultaneously.


Types:

1. Equal-size partitions: All partitions are of the same size.

2. Unequal-size partitions: Partitions vary in size, allowing for more flexible allocation but still suffer from internal fragmentation.


2. Dynamic partitioning Definition: Unlike fixed partitioning, dynamic partitioning creates partitions dynamically at runtime based on the needs of processes. When a process is loaded into memory, a partition is created that exactly matches its size.

• Advantages: 

Better memory utilization as partitions match the process size, reducing internal fragmentation.

• Disadvantages: 

Leads to external fragmentation, where free memory is scattered in small blocks, making it difficult to find contiguous space for large processes.

Requires complex management algorithms to keep track of free and allocated spaces.


3. Simple paging: Main memory is divided into a number of equal-size frames. Each process is divided into a number of equal-size pages of the same length as frames. A process is loaded by loading all of its pages into available, not necessarily contiguous, frames.

• Advantages:

No external fragmentation.

• Disadvantages: 

A small amount of internal fragmentation.


4. Simple segmentation: Each process is divided into a number of segments. A process is loaded by loading all of its segments into dynamic partitions that need not be contiguous.

• Advantages: 

No internal fragmentation; improved memory utilization and reduced overhead compared to dynamic partitioning. 

• Disadvantages:

External fragmentation.


5. Buddy System: The buddy system is a memory allocation algorithm that divides memory into partitions to minimize fragmentation. It works by dividing memory into blocks that are powers of two and pairs them as "buddies."

• Advantages: 

Efficient for dynamic memory allocation and deallocation.

Minimizes external fragmentation by combining free blocks (buddies).

• Disadvantages: 

Can still suffer from internal fragmentation, as processes may be allocated slightly larger memory blocks than needed.

Complexity in merging and splitting blocks.


6. Virtual Memory Paging: As with simple paging, except that it is not necessary to load all of the pages of a process. Nonresident pages that are needed are brought later automatically. 

• Advantages: 

No external fragmentation; 

higher degree of multiprogramming; large virtual address space. 

• Disadvantages: 

Overhead of complex memory management.


7. Virtual Memory Segmentation: As with simple segmentation, except that it is not necessary to load all of the segments of a process. Nonresident segments that are needed are brought in later automatically. 

• Advantages: 

No internal fragmentation, higher degree of multiprogramming; large virtual address space; protection and sharing support. 

• Disadvantages: 

Overhead of complex memory management.


Comments ()


Sign in

Read Next

Cyber Laws In India and Around the World

Blog banner

10 Amazing facts about Tokyo Ghoul

Blog banner

The art of being alone

Blog banner

Indian Culture and Tradition

Blog banner

THE DESIRE OF MANY

Blog banner

A-B-C of Networking: Part-2 (Components)

Blog banner

What is Data, Information and Knowledge?

Blog banner

Threads

Blog banner

COMMUNICATION

Blog banner

Introduction to Data Science: Life Cycle & Applications

Blog banner

Memory management

Blog banner

Full Disk Encryption on Digital Forensics

Blog banner

Vulnerability Assessment

Blog banner

Threads in OS

Blog banner

MENDELEY

Blog banner

Synchronization

Blog banner

COMFORT IS ALL ABOUT FASHION

Blog banner

Digital Footprints An Emerging Dimension of Digital Inequality

Blog banner

Data Mining

Blog banner

Office Lunch Problems in Mumbai and How Tiffin Services Solve Them

Blog banner

Unlocking the Secrets: Basic Operations of Computer Forensic Laboratories

Blog banner

Deadlock and Starvation

Blog banner

The Power of Cyber Forensic in Solving Crimes

Blog banner

Blockchain

Blog banner

Data-Driven Prediction of Virtual Item Prices in Online Games

Blog banner

Embedded Operating System

Blog banner

Pink sauce pasta

Blog banner

Race Condition

Blog banner

LEMON PICKLE (NIMBU KA ACHAR)

Blog banner

Information Technology In E- Commerce

Blog banner

Data Science & AI

Blog banner

“Shot on iPhone” : A campaign by Apple that turned into a prodigy

Blog banner

History of ITIL

Blog banner

Search Marketing In 2026: From Keywords To Credibility And User Intent

Blog banner

Harsh Rathod

Blog banner

Self-love: Being the reason of your own smile

Blog banner

Health and fitness

Blog banner

Exploring Virtual Machines and Computer Forensic Validation Tools

Blog banner

Deadlock and starvation

Blog banner

Security Issues

Blog banner

Security issues

Blog banner

Tiranga - Abbas Haveliwala

Blog banner