我已经实现了一个 LRU 缓存。插入新项目的过程如下所示:
- 检查干草堆中是否有足够的空间。如果是,请跳至 4。
- 删除最近最少使用的项目。
- 检查是否有足够的空间。如果没有,请重复 2。
- 在可用空间中插入项目。
物品在大海捞针中有效地随机排序。
当需要插入比以前的项目更大的项目时,就会出现问题。它会导致“大规模驱逐”,在这种情况下,它会继续驱逐,直到有足够的项目被驱逐,以至于恰好有几个连续的项目被驱逐。
这种“大规模驱逐”通常涉及驱逐数以万计的物品。
可以做些什么来避免或减轻这种“大规模驱逐”?