程序的
局部性原理是指程序在执行时呈现出局部性规律,即在一段时间内,整个程序的执行仅限于程序中的某一部分。相应地,执行所访问的
存储空间也局限于某个内存区域。局部性原理又表现为:
时间局部性和
空间局部性。时间局部性是指如果程序中的某条指令一旦执行,则不久之后该指令可能再次被执行;如果某数据被访问,则不久之后该数据可能再次被访问。空间局部性是指一旦程序访问了某个
存储单元,则不久之后,其附近的存储单元也将被访问。
另外,根据程序的局部性理论,Denning提出了
工作集理论。所谓工作集是指进程
运行时被频繁访问的页面集合。显然我们知道只要使程序的工作集全部集中在内存中,就可以大大减少进程的缺页次数;否则会使进程在运行过程中频繁出现
缺页中断,从而出现频繁的页面调入/调出现象,造成
系统性能的下降,甚至出现“抖动”。
划分工作集可以按定长时间或定长页面两种方法进行划分。当颠簸现象发生时,说明系统的负荷过大,通常采用处理器均衡调度。另一种是控制
缺页率,当缺页率达到上限时,则增加
内存分配量;当缺页率达到下限时,就减少内存的分配量。