Linux内核中使用的数据结构和算法

  • Radix Tree(基树)
    在页缓存管理中的使用:
    页缓存管理中会使用到基树,address_space结构体中包含一个radix tree基树成员,因为每次内核在进行I/O操作前都会检索页高速缓存,也就是address_space结构体,为了提高检索效率,采用基树来管理和检索页高速缓存,会极大提高效率。在2.6以前的内核版本中,页缓存并不是通过基树来检索,而是通过维护一个全局散列表进行检索,相对与基树,基树相对于这种情况是更大优势。
struct address_space {
..
     struct radix_tree_root  page_tree;  /* radix tree of all pages */
...
};
  • LRU链表

在页管理中的使用:

struct page {
...
	struct list_head lru;
...
};

内存回收使用一个LRU链表来管理,每个页page结构体都会加入到LRU链表。

  • RB Tree(红黑二叉树)

1.用户空间虚拟内存区管理中的使用
在vm_area_struct中会使用红黑树:

struct vm_area_struct {

    /* linked list of VM areas per task, sorted by address */
    struct vm_area_struct *vm_next, *vm_prev;

    struct rb_node vm_rb;
};

vm_area_struct中包含红黑树和链表,两种方式来管理vm_area_struct对象,链表用于遍历,而红黑树用于查找,优化了查找效率。

2.在调度器中的使用
CFS调度器中用于管理进程,按照vruntime进行排序,会使用到红黑树来进行管理。

struct rb_root_cached {
    struct rb_root rb_root;
    struct rb_node *rb_leftmost;
};


struct cfs_rq {
...
    struct rb_root_cached tasks_timeline;
...
};

一个runqueue运行队列中会有一个红黑树用来管理运行队列中的进程,其中会按照vruntime来排序,最左变的叶子节点vruntime最少。

  • hash链表

在很早的内核版本O(1)调度器中会使用hash链表管理进程。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值