Table of content:
- What Is An Operating System?
- What Is The Importance Of Operating Systems?
- What Are The Functions Of Operating System?
- Services Provided By Operating System
- Types Of Operating System
- Some Popular Operating Systems
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- What Is An Operating System?
- Types Of Operating Systems
- Batch OS | Types Of Operating Systems
- Multi-Programming OS | Types Of Operating Systems
- Multi-Processing OS | Types Of Operating Systems
- Multi-Tasking OS | Types Of Operating Systems
- Time-Sharing OS | Types Of Operating Systems
- Distributed OS | Types Of Operating Systems
- Network OS | Types Of Operating Systems
- Real-Time OS | Types Of Operating Systems
- Mobile OS | Types Of Operating Systems
- History Of Operating System
- Operating Systems in Business: Achieving Maximum Utilization
- Advantages & Disadvantages of Operating Systems
- Popular Operating Systems In The Market
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- What is a Process in Programming?
- What is Process Scheduling in OS?
- The Need for Process Scheduling in OS
- What is CPU Scheduling Algorithm?
- Different Types of CPU Scheduling Algorithms
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- Evolution & Generations Of Computers
- Definition Of A Computer System
- Components & Classification Of Computer Systems
- Basics Of Computer Networking & The Internet
- Introduction To Operating Systems
- Exploring Computer Memory & Storage
- Importance Of Computer Security & Privacy
- Applications Of Computer Fundamentals
- Job Prospects With Computer Fundamentals
- Frequently Asked Questions (FAQs)
- Master Your Skills: Quiz Time!
Table of content:
- Types of threads per process
- Introducing Thread Models
- What is Multithreading?
- Advantages of Multithreading
- Disadvantages of Multithreading
- Multithreading Models
- Multithreading Vs. Multitasking
- Difference between Process, Kernel Thread and User Thread
- Conclusion
- FAQs
- Test Your Skills: Quiz Time
Table of content:
- What is Booting Process?: Understanding the Types
- Steps in the Booting Process of Computer
- Boot Sequence in Operating System
- Booting Process: Evolution & Troubleshooting
- What is Secure Boot?
- What is Dual Booting?
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- What is A Counter?
- Difference Between Synchronous And Asynchronous Counters
- What is an Asynchronous Counter?
- What Is A Synchronous Counter?
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- History Of Mutex And Semaphore
- Difference Between Mutex And Semaphore
- What Is A Mutex?
- What Is A Semaphore?
- Common Facts About Mutex And Semaphore
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- What is a File?
- What is a Folder?
- Difference between File and Folder
- Summing Up
- Test Your Skills: Quiz Time
Table of content:
- Paging
- Advantages of Paging
- Disadvantages of Paging
- Segmentation
- Advantages of segmentation
- Disadvantages of segmentation
- Difference between Paging and Segmentation
- Conclusion
- FAQs
- Test Your Skills: Quiz Time
Table of content:
- Types of Fragmentation
- Internal Fragmentation
- External Fragmentation
- Difference between Internal and External Fragmentation
- Summing up
- Test Your Skills: Quiz Time
Table of content:
- What is Paging in OS?
- Characteristics of Paging in OS
- Paging in OS: Page Table
- Paging with TLB (Translation Look-aside Buffer)
- Advantages of Paging in OS
- Disadvantages of Paging in OS
- Summing Up
- Frequently Asked Questions
- Test your skills: Quiz Time
Table of content:
- What Is Starvation In OS?
- Starvation In OS: Common Causes
- What Is Deadlock?
- Difference Between Deadlock And Starvation in OS
- Solutions To Starvation In OS
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- Introduction to DOS: A brief history
- Introduction to Windows: A brief history
- Working of DOS
- Working of Windows
- Line of difference: DOS versus Windows
- Versions of DOS and Windows
- Summing Up
- Test Your Skills: Quiz Time
Table of content:
- Understanding File And Directory In OS
- The Directory Structure In OS
- Types Of Directory Structure In OS
- Directory Implementation In OS
- Conclusion
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- What is the purpose of CPU scheduling?
- What is preemptive scheduling?
- What is a non-preemptive scheduling method?
- Comparison between preemptive and non-preemptive scheduling
- Basic differences between the preemptive and non-preemptive scheduling techniques
- Advantages of preemptive scheduling -
- Disadvantages of preemptive scheduling
- Advantages of non-preemptive scheduling -
- Disadvantages of non-preemptive scheduling
- Test Your Skills: Quiz Time
Table of content:
- What Is Multiprogramming?
- Advantages of Multiprogramming Operating System
- Disadvantages of Multiprogramming Operating System
- What Is Multitasking?
- Advantages of Multitasking Operating System
- Disadvantages of Multitasking Operating System
- Multiprogramming Vs Multitasking
- Frequently Asked Questions
- Test Your Skills: Quiz Time
Table of content:
- Character User Interface
- Advantages of CUI
- Disadvantages of CUI
- Graphical User Interface
- Advantages of GUI
- Disadvantages of GUI
- Major Differences Between CUI and GUI
- Summing Up
- Test Your Skills: Quiz Time
Know The Difference Between Internal And External Fragmentation

Fragmentation in an operating system refers to the phenomenon where available memory or storage becomes divided into small, non-contiguous segments. This can happen in physical memory (RAM) and secondary storage (hard drives, SSDs). Fragmentation can negatively impact system performance, efficiency, and overall resource utilization. It is actually an unwanted issue and leads to the following problems.
- The efficiency of the operating system is reduced.
- Memory space is inadequate for use.
- Storage capacity remains unused for many processes.
Types of Fragmentation
There are two types of fragmentation in an OS:
1. Internal Fragmentation
2. External Fragmentation
There is another type of fragmentation called data fragmentation, which combines the two forms of fragmentation together. Let us understand the two types of fragmentation in detail below.
Internal Fragmentation
Internal fragmentation allocates larger memory blocks for a process such that the extra unused spaces in the memory left after allocation are wasted.
In this type of fragmentation, when a process or method requests memory, the system allocates memory split in the form of mounted-sized blocks. This shows that the memory allocated is larger than the memory requested, with the difference between the assigned memory and the memory request as the internal fragmentation.
Internal Fragmentation Process
In this process,
- CPU processor receives information about the process to be executed from a computer program.
- The primary memory stores the process in the form of a fixed-sized block called a page. These processes include heap, register, code, etc., and the pages here have a role to play in paging, where pages can access and move the data from secondary memory to primary memory.
- A particular memory block in the form of fragmented memory spaces is assigned for the process.
- If the assigned memory block is very large, larger than the process, it leads to memory wastage.
Due to this, the overheads increase, which keeps the used and unused data of the process in check. The internal fragmentation process cannot be eliminated but can definitely be reduced by using a best-fit block to the memory.
Properties
- Storage space is regulated by reserving space for processes in storage systems.
- The useless space is called fixed segments, which utilize an enormous chunk of data from the excessive memory.
- Inner fragmentation cannot be restored here, but overhead space can be increased.
- For example, in dynamic storage allocation, overhead spaces according to the number of elements present can be increased by storage reservoirs to reduce this problem.
External Fragmentation
External fragmentation is a fragmentation type that allows the allocation of enough memory space for a process to completely fit in the blocks of memory, but the space is in a non-contiguous manner for memory fragments, and hence, there is unused memory space that is wasted. Shuffle memory content into a large block of memory, compaction, paging, or segmentation of free space is used to place all free memory into one large block to solve this problem of memory wastage due to unused blocks in external fragmentation. Dynamic relocation is done in order to make compaction feasible.
In this form of fragmentation, when memory is requested for allocating a method, a first-fit and best-fit memory allocation strategy is followed, such that a non-contiguous block but a sufficient enough quantity of memory is assigned to the method.
External Fragmentation Process
In this process,
- CPU scheduling is used to store particular data of a process in the memory.
- The data is randomly stored in the memory.
- If the next process is received, it will take another chunk of memory to be stored during the execution time.
- If the first process is removed, the data in the memory leaves a hole in memory space beside the free memory, leading to memory wastage.
Properties
- Inaccessible space is, in case of this type, stored outside the allocated portions.
- Here, different-sized files are formed, resized, and discarded.
- It cannot schedule memory effectively and hence is disadvantageous for all kinds of systems.
- Unused storage is available but is limited, in terms of fragmented time slices, to meet the software application demands.
- Total unused memory space is used here to answer all the allocation requests received.
- For example, For three consecutive memory blocks, if the middle block is removed, then the memory allocator allocates this middle block for further processes.
Difference between Internal and External Fragmentation
The main differences between internal and external fragmentation are as follows:
CHARACTERISTIC | INTERNAL FRAGMENTATION | EXTERNAL FRAGMENTATION |
Type of memory block square appointed | Fixed-sized memory block square measure is assigned for a process. | Variable-sized memory block square measure is assigned for a method. |
Size of memory block | Large memory block is assigned to a process. | Memory block allocated is sufficient enough for the process. |
Solution of the fragmentation problem | Internal fragmentation problem can be solved by best-fit block. It can be solved by allocating the smallest partition, sufficient enough for the process or method. | Techniques like shuffle memory content can solve this into a large block, compaction, paging or segmentation of free space. |
Type of partitioning |
It shows fixed partitioning where the memory assigns fixed size of partitions to the process before loading it. | It shows dynamic partitioning where the memory assigns variable size of partitions to the process before loading it. |
Size of partitions | Memory is divided into fixed sized partitions or segments called pages. | Memory is divided into variable-sized partitions, where division is based on the size of processes. |
Processes that occur | This fragmentation occurs along with fixed partitioning and paging. | This occurs along with segmentation and dynamic partitioning. |
Size of memory allocated | More memory is allocated than required or requested. | Memory allocated is of same memory space as required by the process. |
Unused memory space | The unused memory space is because of the different sizes of the requested and allocated memory. | The unused memory space is because of the non-contiguous memory fragments or chunks of memory, which are too small for a process. This is also called non-used memory voids. |
Occurrence | It occurs when a process consumes less space than was allocated. | It occurs when a method is removed from the main memory of the OS. |
Comparison between procedure and process | It occurs when procedure is greater than the process or method. | It can be seen when the procedure is withdrawn or removed. |
First-fit and Best-fit | First-fit and best-fit does not occur here | First-fit and Best-fit occur here. |
Summing up
This article discusses the following concepts:
- Fragmentation is the process of division of a particular memory space into smaller segments that leave enough memory unused to store various processes.
- It reduces the efficiency of the OS, leaving unused storage capacity as well as an inadequate amount of memory space.
- There are two types of memory fragmentation which are internal fragmentation and external fragmentation.
- In summary, internal fragmentation pertains to wasted space within allocated blocks due to fixed-size allocation, while external fragmentation involves scattered gaps between allocated blocks, making it challenging to allocate large contiguous blocks of memory or storage. Both types of fragmentation can impact resource utilization and system performance and are important considerations in memory and storage management strategies.
It is important for operating systems and applications to manage fragmentation effectively to ensure optimal performance and efficient resource utilization. Different strategies are used based on the specific requirements and characteristics of the system and storage devices.
Test Your Skills: Quiz Time
Hope this article was helpful. Here are some more that you may like to read:
I am a biotechnologist-turned-writer and try to add an element of science in my writings wherever possible. Apart from writing, I like to cook, read and travel.
Comments
Add commentLogin to continue reading
And access exclusive content, personalized recommendations, and career-boosting opportunities.

Subscribe
to our newsletter
Sai Srihitha Mallela 1 month ago
Hruthik Anugula 1 month ago
Sidratul Zuha Mohammad 1 month ago
Niyati Raj 1 month ago
Madala Jeswitha durga 1 month ago
Aswathi P 1 month ago