linux内核(2.6)中的双循环链表浅析

       Linux 2.6内核链表数据结构的实现

 

在计算机科学中,链表是非常通用的数据结构,贯穿于整个linux的内核。在linux内核中,链表通常以
双循环链表的方式出现。所有链表的代码在include/linux/list.h文件中。
定义如下:

这里的list_head没有数据域。在Linux内核链表中,不是在链表结构中包含数据,而是在数据结构中包含链表。
list.h还定义了许多使用的宏和内联函数,下面介绍几个典型的:

在linux的宏定义中,时常用到do{}while(0),这是为了方便再宏定义中包含多行代码,
关于这个的说明在网上可以找到很多详细的介绍。
在宏INIT_LIST_HEAD中,将它初始化为前后都指向自己

在linux内核的链表中,一个空链表定义如下: head->next指向链表的头元素。

list.h中还定义了 list_add() , list_add_tail(),list_del()等基本的链表操作函数,都是比较简单的
C语言这里不详述。
 
在list.h中极其有用的一个宏是list_for_each_entry

它可以遍历整个链表,在linux用的非常广泛,例如当CPU开始工作时,激活在工作队列中的每个进程
-----------------------------------------------------------------------------
kernel/workqueue.c
59 struct workqueue_struct {
60   struct cpu_workqueue_struct cpu_wq[NR_CPUS];
61   const char *name;
62   struct list_head list; /* Empty if single thread */
63 };
  ...
466   case CPU_ONLINE:
467     /* Kick off worker threads. */
468     list_for_each_entry(wq, &workqueues, list)
469         wake_up_process(wq->cpu_wq[hotcpu].thread);
470     break;
-----------------------------------------------------------------------------

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值