linux内核双链表的特点,嵌入式linux内核数据结构之双向链表

嵌入式linux内核双向链表的组织与存储

在单向链表中,每个节点中只包括一个指向下个节点的指针域,因此要在单向链表中插入一个新节点,就必须从链表头指针开始逐个遍历链表中的节点。双向链表与单向链表不同,它的每个节点中包括两个指针域,分别指向该节点的前一个节点和后一个节点,如图1.1所示:

d82074e0f70c893289082d8336458370.png

图1.1 双向链表结构

这样,在双向链表中由任何一个节点都可以很容易地找到其前面的节点和后面的节点,而不需要在上述的插入(及删除)操作中由头节点开始寻找,定义双向链表的节点结构为:

struct link_node

{

element_type data; /*element_type为有效数据类型*/

struct link_node *next;

struct link_node *priv;

};

嵌入式linux内核双向链表的常见操作

(1)增加节点

在双向链表中增加一个节点要比在单链表中的插入操作复杂地多,因为在此处节点next指针和priv指针会同时变化,如图1.2所示:

b623bab0d4a6db03ed543068ecbfae92.png

图1.2 双向链表插入操作

由图中可以看出,在双向链表中增加一个节点会依次完成以下操作。

●  创建新节点

●  使B前方指向C:B→priv = C。

●  使C后方指向B:C→next = B。

●  使A后方指向C:A→next = C。

●  使C前方指向A:C→priv = A。

(2)删除节点

双链表中删除节点与单链表类似,也是增加过程的反操作,如图1.3所示

6c8ab5e1664a430b9dbfeb2cf85f5328.png

8e478ff64a9aa17c0b791508c27984e8.png

图1.3 双向链表删除操作

由图中可以看出,在双向链表中删除元素指针会依次有以下变化。

●  使C前方指向A:C→priv = A。

●  使A后方指向C:A→next = C。

●  使B前后方指向NULL:B->priv = NULL和B->next = NULL ,或(若不再需要该节点)释放节点B。

热点链接:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值