Linux学习------分析list.h 之 函数部分

      在Linux中,最常见也是最经典的数据结构就是其中的双向链表,而对双向链表的各种操作都存储在list.h头文件中,最近仔细看了一下这个头文件,把我对它的理解记录下来,算是一个学习笔记吧。我看的是2.6.35.4版本的内核源代码,list.h在include/linux下存放,相对于一些其他的内核原文件来说,list.h算是比较小的了,而且只有700多行,主要是因为这个文件算是一个纯C文件,就是它是单纯的用C语言来对双向链表进行操作,看起来也比较容易。
      在list.h中,定义了如下一个数据结构:

这是一个双向链表,但是不存储数据,只是做一个相互连接的作用,定义了一个指向后一元素的指针和指向前一元素的指针。定义这样一个没有存储数据的数据结构,我觉得好处是可以广泛嵌套使用,把它当做一座桥,只是连接,然后再配合上其他变量来存储数据,一起形成一个结构体,这样后面对其操作就可以通用了,不必换一种数据就换一堆操作了。
      对于双向链表的初始化,list.h中给出了两个方法,一个是宏定义的方法,另一个是函数的方法:

前两个宏定义要结合起来看,第二个宏定义是一个结构体的赋初值,再看第一个宏定义,就是说把name这个list_head类型的结构体的第一个元素赋值为name的地址,第二个元素也赋值为name的地址,再结合上面的结构体的定义,就是说把name->next和name->prev都赋值为name自己,也就是指向自身,这样就是初始化好了一个双向链表的结点。而第二种用函数的方法就是直接把我上面的分析转换成代码的形式了,意思和功能是一样的。
      对于链表的操作不过是“增删改查”几种,双向链表也不例外。
      一、在进行增加操作时,list.h中的代码如下:

总共定义了三个函数,大致一看,后两个是调用了第一个函数。对于第一个函数,首先分析它的参数是什么,第一个参数new,是一个类型为list_head的指针,指向要增加的结点,而prev和next也都是list_head类型的指针,顾名思义,就是指向增加的位置的前面和后面的结点ÿ
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值