页面置换算法,在一个支持虚拟分页并采用请求页式调度的存储管理系统中,有一用户程序,它访问其地址空间的字地址序列是:70、74、135、276、400、300、700、266、148、560、284、172(以上数字为虚存的逻辑地址)。问: (1). 若分配给该作业的内存大小为384字,初始为空,页大小为128字,对于以上的存储器引用序列,给出其页面走向。 (2). 试按FIFO、LRU页面淘汰算法,分别计算页面访问的缺页次数和缺页率?
时间: 2023-07-10 17:10:18 浏览: 273
好的,我来回答您的问题:
(1) 若分配给该作业的内存大小为384字,初始为空,页大小为128字,对于以上的存储器引用序列,给出其页面走向。
首先,根据页大小可知,一个页面可存放128字,所以该程序需要的页面数为:
(70+127)/128 + (74+127)/128 + (135+127)/128 + (276+127)/128 + (400+127)/128 + (300+127)/128 + (700+127)/128 + (266+127)/128 + (148+127)/128 + (560+127)/128 + (284+127)/128 + (172+127)/128 = 11
因此,该程序需要11个页面才能存放完所有数据。由于分配给该作业的内存大小为384字,初始为空,因此只能分配3个页面,即384字/128字/页面=3个页面。页面走向如下:
| 访问地址 | 页号 | 页面内容 |
|----------|------|----------|
| 70 | 0 | 70 |
| 74 | 0 | 70、74 |
| 135 | 1 | 135 |
| 276 | 2 | 276 |
| 400 | 3 | 400 |
| 300 | 2 | 276、300 |
| 700 | 5 | 700 |
| 266 | 2 | 300、266 |
| 148 | 1 | 135、148 |
| 560 | 4 | 560 |
| 284 | 2 | 266、284 |
| 172 | 1 | 148、172 |
(2) 试按FIFO、LRU页面淘汰算法,分别计算页面访问的缺页次数和缺页率。
FIFO页面淘汰算法:
| 访问地址 | 页号 | 页面内容 | 缺页次数 | 缺页率 |
|----------|------|----------|---------|--------|
| 70 | 0 | 70 | 1 | 33.33%|
| 74 | 0 | 70、74 | 1 | 33.33%|
| 135 | 1 | 70、74、135 | 2 | 66.67%|
| 276 | 2 | 74、135、276 | 3 | 100.00%|
| 400 | 3 | 135、276、400 | 4 | 133.33%|
| 300 | 2 | 276、400、300 | 5 | 166.67%|
| 700 | 5 | 400、300、700 | 6 | 200.00%|
| 266 | 2 | 300、700、266 | 7 | 233.33%|
| 148 | 1 | 700、266、148 | 8 | 266.67%|
| 560 | 4 | 266、148、560 | 9 | 300.00%|
| 284 | 2 | 148、560、284 | 10 | 333.33%|
| 172 | 1 | 560、284、172 | 11 | 366.67%|
LRU页面淘汰算法:
| 访问地址 | 页号 | 页面内容 | 缺页次数 | 缺页率 |
|----------|------|----------|---------|--------|
| 70 | 0 | 70 | 1 | 33.33%|
| 74 | 0 | 70、74 | 1 | 33.33%|
| 135 | 1 | 70、135、74 | 2 | 66.67%|
| 276 | 2 | 135、74、276 | 3 | 100.00%|
| 400 | 3 | 74、276、400 | 4 | 133.33%|
| 300 | 2 | 276、400、300 | 5 | 166.67%|
| 700 | 5 | 400、300、700 | 6 | 200.00%|
| 266 | 2 | 400、700、266 | 7 | 233.33%|
| 148 | 1 | 700、266、148 | 8 | 266.67%|
| 560 | 4 | 266、148、560 | 9 | 300.00%|
| 284 | 2 | 148、560、284 | 10 | 333.33%|
| 172 | 1 | 560、284、172 | 11 | 366.67%|
其中,缺页次数是指程序运行过程中,需要从虚拟内存中读取的页面数量,缺页率是指缺页次数占所有页面访问次数的比例。可以看出,在FIFO和LRU页面淘汰算法下,缺页次数和缺页率都是相同的,因为页面淘汰算法不会影响整个程序的页面走向。
阅读全文