#allocator #buddy #finding #algorithm #bitmap #usize #伙伴分配器。

no-std customizable-buddy

A new buddy allocator that allows custom buddy finding algorithm

3 releases

0.0.3 Oct 11, 2022
0.0.2 Sep 20, 2022
0.0.1 Sep 14, 2022

#419 in Memory management

Download history 38/week @ 2024-02-25 22/week @ 2024-03-03 31/week @ 2024-03-10 21/week @ 2024-03-17 21/week @ 2024-03-24 71/week @ 2024-03-31 13/week @ 2024-04-07 29/week @ 2024-04-14 19/week @ 2024-04-21 8/week @ 2024-04-28 6/week @ 2024-05-05 13/week @ 2024-05-12 13/week @ 2024-05-19 14/week @ 2024-05-26 19/week @ 2024-06-02 7/week @ 2024-06-09

55 downloads per month

MIT license

28KB
572 lines

伙伴分配器

Latest version Documentation license CI issue

伙伴分配器。

用法参见性能测试示例自定义实现示例

与常见的实现的区别:

  • 定义了伙伴行*的接口,支持替换伙伴查找算法。内置 usize bitmap 和单链表实现,可以自定义实现;
  • 定义了寡头行的不同接口。伙伴分配器定义为一个二叉森林,可以有多个根。所有根的集合是最顶层的一行,因为没有相邻伙伴合并的行为,称为寡头行;
  • 使用 transfer 将内存块转移给分配器,使用 snatch 从分配器取出内存块,动态控制分配器管理的内存块;
  • 不包含锁或加锁版本的接口,要实现 GlobalAllocAllocator 需要自定义可变性管理方式;

    单线程的应用建议不加锁,用某种 Cell 描述可变性;

  • 带有多种分配接口,分别基于一个类型、一个布局描述或原始参数分配;

NOTICE “行”是 háng。意为伙伴分配器管理的同样大小的那一组块。

No runtime deps