1、belady异常:对于FIFO页面置换算法,分配页面数增多,缺页率反而提高的异常。
2、最优置换算法:将最长时间不被使用的页置换掉。如:*表示缺页,下面案例九次缺页。
即需要替换时,从当前内存中找,对应的后面即将调度的最后出现的页(最长时间不被调度)
7 |
0 |
1 |
2 |
0 |
3 |
0 |
4 |
2 |
3 |
0 |
3 |
2 |
1 |
2 |
0 |
1 |
7 |
0 |
1 |
7 |
7 |
7 |
2 |
2 |
2 |
2 |
2 |
7 | |||||||||||
0 |
0 |
0 |
0 |
4 |
0 |
0 |
0 | ||||||||||||
1 |
1 |
3 |
3 |
3 |
1 |
1 | |||||||||||||
* |
* |
* |
* |
* |
* |
* |
* |
* |
3、最近最少使用算法(LRU)Least Recent Used Algorithm。如:下面案例12次缺页。(使用栈进行更新)最近被替换的页号放于栈顶,每次换出的是栈底对应页。
7 |
0 |
1 |
2 |
0 |
3 |
0 |
4 |
2 |
3 |
0 |
3 |
2 |
1 |
2 |
0 |
1 |
7 |
0 |
1 |
7 |
7 |
7 |
2 |
2 |
4 |
4 |
4 |
0 |
1 |
1 |
1 | ||||||||
0 |
0 |
0 |
0 |
0 |
0 |
3 |
3 |
3 |
0 |
0 | |||||||||
1 |
1 |
3 |
3 |
2 |
2 |
2 |
2 |
2 |
7 | ||||||||||
* |
* |
* |
* |
* |
* |
* |
* |
* |
* |
* |
* |
4、使用工作集模型可以有效控制系统抖动,在一定的工作集内的数据无需进行缺页置换,利用程序局部的近似可减少缺页错误频率,如进入一个函数后,反复掉的数据基本都在同一个工作集内。
5、采用缺页错误频率策略能更有效地控制系统抖动,当缺页错误频率超过上限,就适当分配帧;当低于下限,说明进程很闲,可以适当删除已分配给进程的帧。