<< Chapter < Page | Chapter >> Page > |
Thrashing occurs when a system spends more time swapping than running a process. The operating system can avoid thrashing by reducing the number of processes that are in memory, i.e. by swapping some out.
The advantage of having a fixed resident set means that no other process can take frames away from you. However, this has to take into account the maximum need of a process and so it may waste memory. The advantage of having a dynamic resident set means the number of frames dedicated to a process can grow or shrink over time, more closely matching its needs. Of course, there is more overhead involved with this approach.
A fixed size resident set implies a local replacement policy. Any time a process needs a new page, one of its own pages must be replaced.
Having a variable resident set allows the operating system to do either local or global replacement. Doing local replacement means that the process always replaces one of its own frames and the resident set size can be increased or decreased separately by the operating system. Doing global replacement means the process can automatically increase its resident set by choosing to replace someone else's page with its own. It may also have its resident set decreased when someone else chooses one of its pages.
Precleaning may decrease the page fault rate if the operating system is able to bring in pages in advance of them being used by a process. This may be particularly effective at the time the process is first loaded.
Problems
The shaded areas are allocated blocks; the white areas are free blocks. The next three memory requests are for 40M, 20M, and 10M. Indicate the starting address for each of the three blocks using the indicated placement algorithms:
1. First-fit
* The 40 M block fits into the second hole, with a starting address of 80M.
* The 20M block fits into the first hole, with a starting address of 20M.
* The 10M block is placed at location 120M.
2. Best-fit
The three starting addresses are 230M, 20M, and 160M, for the 40M, 20M, and 10M blocks, respectively.
3. Next-fit. Assume the most recently added block is at the beginning of memory.
The three starting addresses are 80M, 120M, and 160M, for the 40M, 20M, and 10M blocks, respectively.
4. Worst-fit
The three starting addresses are 80M, 230M, and 360M, for the 40M, 20M, and 10M blocks, respectively.
a. Show the results of the following sequence in a figure similar to Figure 7.6: Request 70; Request 35; Request 80; Return A; Request 60; Return B; Return D; Return C.
Notification Switch
Would you like to follow the 'Operating systems' conversation and receive update notifications?