Virtual memory is a memory management technique that uses secondary storage like a hard drive as an extension of primary memory (RAM). It allows the system to run programs larger than available RAM by swapping unused portions of programs/data between RAM and secondary storage. When RAM is full, the operating system moves less frequently used portions to secondary storage to make room for active portions, simulating more RAM than is physically installed. Page replacement algorithms in virtual memory determine which memory pages to swap out when new pages need to be loaded.
Virtual memory is a memory management technique that uses secondary storage like a hard drive as an extension of primary memory (RAM). It allows the system to run programs larger than available RAM by swapping unused portions of programs/data between RAM and secondary storage. When RAM is full, the operating system moves less frequently used portions to secondary storage to make room for active portions, simulating more RAM than is physically installed. Page replacement algorithms in virtual memory determine which memory pages to swap out when new pages need to be loaded.
Virtual memory is a memory management technique that uses secondary storage like a hard drive as an extension of primary memory (RAM). It allows the system to run programs larger than available RAM by swapping unused portions of programs/data between RAM and secondary storage. When RAM is full, the operating system moves less frequently used portions to secondary storage to make room for active portions, simulating more RAM than is physically installed. Page replacement algorithms in virtual memory determine which memory pages to swap out when new pages need to be loaded.
Virtual memory is a memory management technique that uses secondary storage like a hard drive as an extension of primary memory (RAM). It allows the system to run programs larger than available RAM by swapping unused portions of programs/data between RAM and secondary storage. When RAM is full, the operating system moves less frequently used portions to secondary storage to make room for active portions, simulating more RAM than is physically installed. Page replacement algorithms in virtual memory determine which memory pages to swap out when new pages need to be loaded.
Virtual memory is a memory management technique where secondary memory
can be used as if it were a part of the main memory. Virtual memory is a common technique used in a computer's operating system (OS). Virtual memory uses both hardware and software to enable a computer to compensate for physical memory shortages, temporarily transferring data from random access memory (RAM) to disk storage. Mapping chunks of memory to disk files enables a computer to treat secondary memory as though it were main memory. Today, most personal computers (PCs) come with at least 8 GB (gigabytes) of RAM. But, sometimes, this is not enough to run several programs at one time. This is where virtual memory comes in. Virtual memory frees up RAM by swapping data that has not been used recently over to a storage device, such as a hard drive or solid-state drive (SSD). Virtual memory is important for improving system performance, multitasking and using large programs. However, users should not overly rely on virtual memory, since it is considerably slower than RAM. If the OS has to swap data between virtual memory and RAM too often, the computer will begin to slow down -- this is called thrashing. Virtual memory was developed at a time when physical memory -- also referenced as RAM -- was expensive. Computers have a finite amount of RAM, so memory will eventually run out when multiple programs run at the same time. A system using virtual memory uses a section of the hard drive to emulate RAM. With virtual memory, a system can load larger or multiple programs running at the same time, enabling each one to operate as if it has more space, without having to purchase more RAM. How Virtual Memory Works? In modern word, virtual memory has become quite common these days. In this scheme, whenever some pages need to be loaded in the main memory for the execution and the memory is not available for those many pages, then in that case, instead of stopping the pages from entering in the main memory, the OS search for the RAM area that are least used in the recent times or that are not referenced and copy that into the secondary memory to make the space for the new pages in the main memory. Since all this procedure happens automatically, therefore it makes the computer feel like it is having the unlimited RAM. For example: Let’s assume that an OS requires 300 MB of memory to store all the running programs. However, there’s currently only 50 MB of available physical memory stored on the RAM. • The OS will then set up 250 MB of virtual memory and use a program called the Virtual Memory Manager(VMM) to manage that 250 MB. • So, in this case, the VMM will create a file on the hard disk that is 250 MB in size to store extra memory that is required. • The OS will now proceed to address memory as it considers 300 MB of real memory stored in the RAM, even if only 50 MB space is available. • It is the job of the VMM to manage 300 MB memory even if just 50 MB of real memory space is available. Demand Paging A demand paging mechanism is very much similar to a paging system with swapping where processes stored in the secondary memory and pages are loaded only on demand, not in advance. Demand Paging is a popular method of virtual memory management. In demand paging, the pages of a process which are least used, get stored in the secondary memory. A page is copied to the main memory when its demand is made or page fault occurs. There are various page replacement algorithms which are used to determine the pages which will be replaced. What is Page Replacement in Operating Systems? Page replacement is needed in the operating systems that use virtual memory using Demand Paging. As we know that in Demand paging, only a set of pages of a process is loaded into the memory. This is done so that we can have more processes in the memory at the same time. When a page that is residing in virtual memory is requested by a process for its execution, the Operating System needs to decide which page will be replaced by this requested page. This process is known as page replacement and is a vital component in virtual memory management. Why Need Page Replacement Algorithms? To understand why we need page replacement algorithms, we first need to know about page faults. Let’s see what is a page fault. Page Fault: A Page Fault occurs when a program running in CPU tries to access a page that is in the address space of that program, but the requested page is currently not loaded into the main physical memory, the RAM of the system. Since the actual RAM is much less than the virtual memory the page faults occur. So whenever a page fault occurs, the Operating system has to replace an existing page in RAM with the newly requested page. In this scenario, page replacement algorithms help the Operating System in deciding which page to replace. The primary objective of all the page replacement algorithms is to minimize the number of page faults. Page Replacement Algorithms in Operating Systems First In First Out (FIFO) FIFO algorithm is the simplest of all the page replacement algorithms. In this, we maintain a queue of all the pages that are in the memory currently. The oldest page in the memory is at the front-end of the queue and the most recent page is at the back or rear-end of the queue. Whenever a page fault occurs, the operating system looks at the front-end of the queue to know the page to be replaced by the newly requested page. It also adds this newly requested page at the rear-end and removes the oldest page from the front-end of the queue. Optimal Page Replacement in OS Optimal page replacement is the best page replacement algorithm as this algorithm results in the least number of page faults. In this algorithm, the pages are replaced with the ones that will not be used for the longest duration of time in the future. In simple terms, the pages that will be referred farthest in the future are replaced in this algorithm. Least Recently Used (LRU) Page Replacement Algorithm The least recently used page replacement algorithm keeps the track of usage of pages over a period of time. This algorithm works on the basis of the principle of locality of a reference which states that a program has a tendency to access the same set of memory locations repetitively over a short period of time. So pages that have been used heavily in the past are most likely to be used heavily in the future also. In this algorithm, when a page fault occurs, then the page that has not been used for the longest duration of time is replaced by the newly requested page. Last In First Out (LIFO) Page Replacement Algorithm This is the Last in First Out algorithm and works on LIFO principles. In this algorithm, the newest page is replaced by the requested page. Usually, this is done through a stack, where we maintain a stack of pages currently in the memory with the newest page being at the top. Whenever a page fault occurs, the page at the top of the stack is replaced. Random Page Replacement in OS This algorithm, as the name suggests, chooses any random page in the memory to be replaced by the requested page. This algorithm can behave like any of the algorithms based on the random page chosen to be replaced. Conclusion • The objective of page replacement algorithms is to minimize the page faults • FIFO page replacement algorithm replaces the oldest page in the memory • Optimal page replacement algorithm replaces the page which will be referred farthest in the future • LRU page replacement algorithm replaces the page that has not been used for the longest duration of time • LIFO page replacement algorithm replaces the newest page in memory • Random page replacement algorithm replaces any page at random • Optimal page replacement algorithm is considered to be the most effective algorithm but cannot be implemented in practical scenarios due to various limitations