浏览代码

RL search

ticki 9 年之前
父节点
当前提交
a651595317
共有 1 个文件被更改,包括 2 次插入1 次删除
  1. 2 1
      src/block_list.rs

+ 2 - 1
src/block_list.rs

@@ -27,7 +27,8 @@ impl BlockList {
     pub fn alloc(&mut self, size: usize, align: usize) -> Unique<u8> {
         let mut ins = None;
 
-        for (n, i) in self.iter_mut().enumerate() {
+        // We run right-to-left, since new blocks tend to get added to the right.
+        for (n, i) in self.iter_mut().enumerate().rev() {
             let aligner = aligner(*i.ptr, align);
 
             if i.size - aligner >= size {