怎么运用linux内核函数提供的双向循环链表

怎么运用linux内核函数提供的双向循环链表,第1张

在linux内核中,有大量的数据结构需要用到双循环链表,例如进程、文件、模块、页面等。若采用双循环链表的传统实现方式,需要为这些数据结构维护各自的链表,并且为每个链表都要设计插入、删除等 *** 作函数。因为用来维持链表的next和prev指针指向对应类型的对象,因此一种数据结构的链表 *** 作函数不能用于 *** 作其它数据结构的链表。

int main()

{

Link head//链表(不带头节点)

int n

printf("输入链表的长度n: ")

scanf("%d",&n)

printf("连续输入%d个数据(以空格隔开): ",n)

head=CreateLink(n)

printf("\n原本链表的节点是: ")

DispLink(head)

LinkSort(head)

printf("\n从大到小排序之后: ")

DispLink(head)

printf("\n")

return 0

}

链表的具体存储表示为:

① 用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的,也可以是不连续的)

② 链表中结点的逻辑次序和物理次序不一定相同。为了能正确表示结点间的逻辑关系,在存储每个结点值的同时,还必须存储指示其后继结点的地址(或位置)信息(称为指针(pointer)或链(link))

链式存储是最常用的存储方式之一,它不仅可用来表示线性表,而且可用来表示各种非线性的数据结构。

以上内容参考:百度百科-单链表

file: linux/include/linux/list.h

19 #define LIST_HEAD_INIT(name) { &(name), &(name) }

20

21 #define LIST_HEAD(name) \

22 struct list_head name = LIST_HEAD_INIT(name)

23

24 static inline void INIT_LIST_HEAD(struct list_head *list)

25 {

26 list->next = list

27 list->prev = list

28 }

LIST_HEAD_INIT是宏,INIT_LIST_HEAD是函数吧,摘自linux-2.6.37.2源码


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7503475.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-06
下一篇 2023-04-06

发表评论

登录后才能评论

评论列表(0条)

保存