您的位置:首页 > 运维架构 > Linux

Linux中TASK_RUNNING状态的进程链表

2012-02-08 16:25 253 查看
早先的Linux版本把所有处于TASK_RUNNING状态的进程组织在一个叫做运行队列(runqueue)的链表中,由于维持链表中的进程按优先级排序的开销过大,因此,早期的调试程序需扫描整个队列以选择“最佳”的可运行程序。

Linux2.6实现的运行队列有所不同。为了实现在固定的时间内选出“最佳”的可运行程序,内核将可运行进程的优先级划分为0-139,并为此建立了140个可运行进程链表,用以组织处于TASK_RUNNING状态的进程,每个进程优先权对应一个不同的链表。此外,在多处理器系统中,每个CPU都有它自己的运行队列。

Linux2.6实现的运行队列结构如下:

类型字段描述
intnr_active链表中进程描述符的数量
unsigned long[5]bitmap优先权位图:当且仅当某个优先权的进程链表不为空时设置相应的位标志
struct list_head[140]queue140个优先权队列的头结点
进程描述符的结构都包含一个list_head类型的tasks字段,这个类型的prev和next字段分别指向前面和后面的task_struct元素,实现双向链表。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: