首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux内核中双向链表的经典实现

概要 本文对双向链表进行探讨,介绍的内容是Linux内核中双向链表的经典实现和用法。其中,也会涉及到Linux内核中非常常用的两个经典宏定义offsetof和container_of。...内容包括: 1.Linux中的两个经典宏定义 2.Linux中双向链表的经典实现 Linux中的两个经典宏定义 倘若你查看过Linux Kernel的源码,那么你对 offsetof 和 container_of...在linux内核的include/linux/kernel.h中定义。...Linux中双向链表的经典实现 1.Linux中双向链表介绍 Linux双向链表的定义主要涉及到两个文件: include/linux/types.h include/linux/list.h Linux...中双向链表的使用思想 它是将双向链表节点嵌套在其它的结构体中;在遍历链表的时候,根据双链表节点的指针获取"它所在结构体的指针",从而再获取数据。

2.7K30

002 Linux内核中双向链表的经典实现

概要 本文对双向链表进行探讨,介绍的内容是Linux内核中双向链表的经典实现和用法。其中,也会涉及到Linux内核中非常常用的两个经典宏定义offsetof和container_of。...内容包括: 1.Linux中的两个经典宏定义 2.Linux中双向链表的经典实现 Linux中的两个经典宏定义 倘若你查看过Linux Kernel的源码,那么你对 offsetof 和 container_of...在linux内核的include/linux/kernel.h中定义。...Linux中双向链表的经典实现 1.Linux中双向链表介绍 Linux双向链表的定义主要涉及到两个文件: include/linux/types.h include/linux/list.h Linux...中双向链表的使用思想 它是将双向链表节点嵌套在其它的结构体中;在遍历链表的时候,根据双链表节点的指针获取"它所在结构体的指针",从而再获取数据。

1.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux内核链表的使用

    /******************** * 内核中链表的应用 ********************/ (1)介绍 在Linux内核中使用了大量的链表结构来组织数据,包括设备列表以及各种功能模块中的数据组织...这些链表大多采用在include/linux/list.h实现的一个相当精彩的链表数据结构。...和以前介绍的双链表结构模型不同,这里的list_head没有数据域。在Linux内核链表中,不是在链表结构中包含数据,而是在数据结构中包含链表节点。...如: struct my_struct{ struct list_head list; unsigned long dog; void *cat; }; linux中的链表没有固定的表头,从任何元素开始访问都可以...定义在linux/list.h> a.增加节点 list_add(struct list_head *new, struct list_head *head); 向指定链表的head

    2.3K30

    JAVA链表中的回文链表结构

    大家好,又见面了,我是你们的朋友全栈君。 作为一个java初学者,最近遇到了回文链表结构这个难题,经过一番学习总算搞清楚个大概。 先来说一下什么是回文链表,会问链表在我们生活中经常能够遇到。...会问链表的结构就是 例如:1->2->3->2->1。我们将它反转过来还是与原链表相同,这种就称为回文结构。...具体方法:1.先找到链表的中间位置 2.然后将中间位置的链表反转 3.从两边向中间遍历 代码如图 class Node {...this.data = data; this.next = null; } } public class MyLinkedList { public Node head;//保存单链表的头节点的引用...//找出链表的中间位置 Node fast = this.head; Node slow = this.head; while(fast !

    49010

    linux通用链表

    引言 链表的实现是基于结构体与指针两者实现的,常用的链表数据结构如下: //将int起别名ELEMTYPE,是为了方便修改链表中的数据域类型。...在Linux中设计了一种适合于各种类型数据域都可以使用的通用型链表: struct list_head { struct list_head *prev, *next; }; 摒弃掉数据域,只保留头尾指针...内核链表 链表的主要意义就是将分散地址的数据域通过指针排列成有序的队列。因此数据域是链表不可或缺的一部分,但是在实际使用中需要不同类型的数据域,因此也就限制了链表的通用。...Linux中在声明中抛弃了数据域,也就解决掉了这一问题。 原理 Linux使用链表的方法:使用时,自定义结构体包含数据域+链表结构体。...链表.png 如上图所示,将结构体A、B、C中的内核结构体指针构建成双链表,这样结构体A、B、C中的链表成员就可以互相索引了。

    1.1K20

    删除链表中的节点

    题目描述 难度级别:简单 请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点。传入函数的唯一参数为 要被删除的节点 。...,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9....示例 2: 输入:head = [4,5,1,9], node = 1 输出:[4,5,9] 解释:给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9....提示: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表中的一个有效节点。 不要从你的函数中返回任何结果。...解题思路 题目中待传递给当前函数的实参node,它是链表中的某一个待删除的节点,然后从链表中删除这个节点。

    2.4K00

    Java 中的链表分析

    容器 我们平时都经常遇到容器这个词,那么 Java 集合中的容器指的是什么呢?容器就是利用某种特定的数据结构来存储数据的。...物理结构就是数据在计算机中是怎么存储的,有数组和链表两种方式。数组是内存中一块连续的存储空间,所以可以随机访问(利用索引就可以访问)。链表是内存中离散的一些存储空间,所以必须要通过头节点来顺序访问。...容器中的元素个数(size) 方便定位到容器中最后一个元素的位置 时间复杂度 这里以 Java 集合中的 LinkedList 为例分析一下时间复杂度。...我们一般在链表的尾部插入一个新的节点不是需要一个循环遍历链表找到最后一个节点,然后修改相应引用的指向吗?那时间复杂度应该是 O(n) 呀。...确实是这样的,但是在 Java 的 LinkedList 中它利用了一个尾指针(引用) 记录了链表最后一个节点的位置,不需要再去遍历链表,所以时间复杂度为 O(1)。

    68020

    Leetcode链表回文 链表分割 链表相交 环形链表I 环形链表II 获取链表中倒数k的节点

    首先求得回文串中的中间位置,因为回文串两边的头节点往中间靠拢,在相同的情况下,如果两边头节点相遇则是回文串 这里我们的fast和slow都从head头部同时走,但是fast一次走两步slow一次只走一步...两个参数一个为链表,一个为x值,将链表中的每一个节点的值与x值比较,小的放在左边,大的放到右边,并且两者的相对位置不变 我们定义两个区间链表来获取小于x的节点和大于x的节点 当链表的节点走完后,将p1...中区域的最后一个值的下一个节点获取到p2头部值即可 这里需要考虑的是如果所有节点的值都是大于x,那么p1就是一个空指针,所以这里当跳出循环后需要增加一个判断条件,如果p1的值仍然为空,则直接返回第二个区域的头节点...=null){ //当p2中有节点时,将循环出来的最后一个节点的next值置空 e2.next=null; } e1.next...=fast){ //当slow==fast返回环形链表中第一个头节点 slow=slow.next; fast=fast.next

    2300

    删除链表中的元素基本操作。链表

    删除链表中等于给定值val的所有节点。 样例 给出链表 1->2->3->3->4->5->3, 和 val = 3, 你需要返回删除3之后的链表:1->2->4->5。 基本操作。...链表 链表有很多种,这里给的是单向链表,链表由节点构成,每一个节点包含两个信息,分别是数据和链(实际上就是一个指针,指向下一个节点,如果没有下一个这个指针为NULL)。...* int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; 这是题目中给出的一个单向链表节点...除此之外还有双向链表(每一个链表有两条链,分别指向前一个和后一个节点),循环链表也是有的,就是收尾又链接起来,显而易见是有单向循环也有双向循环的。...链表的优点: 插入删除方便,只要改变指针的指向就可以,不用像数组一样需要移动数据。 链表的缺点: 因为内存不连续,所以查找效率不高。 它的优缺点和数组刚好是反过来的。

    91210

    链表----在链表中添加元素详解--使用链表的虚拟头结点

    在上一小节中关于在链表中头部添加元素与在其他位置添加元素在逻辑上有所差别,这是由于我们在给链表添加元素时需要找到待添加元素位置的前一个元素所在的位置,但对于链表头来说,没有前置节点,因此在逻辑上就特殊一些...下面对代码进行改写: (1)将之前对头结点的定义改为对虚拟头结点的定义 将原来定义的头结点代码 private Node head; 改为 private Node dummyHead; (2)链表构造函数初始化时对虚拟节点进行初始化...//在链表的index(0--based)的位置添加新的元素e (实际不常用,练习用) public void add(int index, E e) { if (index...LinkedList() { 43 dummyHead = new Node(null, null); 44 size = 0; 45 } 46 47 //获取链表中的元素个数...isEmpty() { 54 return size == 0; 55 } 56 57 //在链表的index(0--based)的位置添加新的元素e (实际不常用

    1.8K20

    237 删除链表中的节点

    01 题目信息 题目地址: https://leetcode-cn.com/problems/delete-node-in-a-linked-list/ 请编写一个函数,使其可以删除某个链表中给定的(非末尾...示例 1: 输入:head = [4,5,1,9], node = 5 输出:[4,1,9] 解释:给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9....提示: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表中的一个有效节点。 不要从你的函数中返回任何结果。...02 题解 作为合集中链表下的第一题,确实是较简单的只是一个单元操作,但如果不知道链表这种数据结构也还是是完成不了的。 链表是什么?...链表是物理存储单元上非连续的、非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,有一系列结点(地址)组成,结点可动态的生成,也就是包含值与模拟指针(引用)。大概如下: ?

    1.3K10

    删除链表中的重复节点.

    前言 在一个排序的链表中,存在重复的节点,如何删除链表中重复的节点并返回删除后的链表头指针?例如:1->2->3->3->4->4->5,处理后为: 1->2->5。...本文将分享这个问题的解决思路与实现代码,欢迎各位感兴趣的开发者阅读本文。 常规思路 根据题意,我们可以知道链表中的元素是排好序的。如果节点重复的话,当前节点一定与下一个节点相同。...其次,我们需要创建两个指针: 一个指向当前不重复的节点,我们将它命名为pre 一个为搜索指针,用于搜索链表中与当前节点不重复的节点,我们将它命名为last 随后,我们为 pre 与 last 进行初始赋值...20220226224625702 实现代码 接下来,我们将上述思路转换为代码,如下所示: /** * 删除链表中的重复节点 * @param pHead 链表头节点 */ deleteDuplicatesNode...* * 删除链表中的重复节点(递归解法) * @param pHead 链表头节点 */ deleteDuplicatesNodeForRecursion(pHead: ListNode

    2.8K40

    链表中快慢指针的应用

    刷了有关链表的一些算法题后,我发现其中用到快慢指针的题不少,像中间节点,倒数第n个节点以及链表成环 链表成环问题我只前发过两篇博客详细的讲了一下 跳转链接 https://blog.csdn.net...code=app_1562916241&uLinkId=usr1mkqgl919blen http://t.csdnimg.cn/e8p9P 今天就来说一下另外两道题 题目链接 leecode链表的中间节点...https://leetcode.cn/problems/middle-of-the-linked-list/description/ 牛客链表中倒数第k个节点 https://www.nowcoder.com...slow = slow->next; fast = fast->next; } } return slow; } 总结 关于这些问题,我们不难发现,在链表中快慢指针的应用相对频繁...,在后续对链表的学习和对有关链表的算法题进行公克的时候,不妨多往快慢指针方面去想想

    9510

    【拿捏链表(Ⅱ)】—Leetcode删除排序链表中的重复元素

    目录 删除排序链表中的重复元素(Ⅰ) 删除排序链表中的重复元素(Ⅱ) 删除排序链表中的重复元素(Ⅰ) 题目: 给定一个已排序的链表的头 head ,删除所有重复的元素,使每个元素只出现一次 。...返回 已排序的链表 。 思路:这里的思路很简单,定义两个指针,一个指向head,一个指向head的后一个节点,然后遍历进行比较即可。...} cur=cur->next; } //最后置空,防止野指针 tail->next=NULL;; return head; } 删除排序链表中的重复元素...(Ⅱ) 题目: 给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。...返回 已排序的链表 思路:该题是上题的升级版本,稍稍复杂了一点点,不过核心思想是一样的,为非就是遍历,然后比较。这里我们用哨兵卫的单链表,方便我们对节点进行比较。

    50220

    链表的实现在PHP中

    Source Code Pro Source Code Pro 步入正题,讲讲链表的操作 节点 首先得有一个节点类,用于存储数据 <?...(用于操作节点数据) 操作类的代码由于太长,我们分部分解析 头插入(因为比较简单,所以先讲这个) 听名字,就知道是从头部插入一个节点 当链表为空,则初始化当前节点 当链表不为空,把新节点作为头结点 public...// 1 2 5 8 9 $manager->insertEnd(9); // 3 $manager->find(8); // 1 2 8 9 $manager->delete(2); 查找 查找链表的值也是很简单的...,只要遍历即可 /** * 查找链表的值中的索引 * 成功返回索引值,找不到返回 -1 * * @param int $data * @return int */ public function find...,找到相等的值,找到返回索引值,找不到返回 -1 删除 /** * 删除链表的节点 * * @param int $index * @return bool */ public function

    11110

    链表——24. 两两交换链表中的节点

    1 题目描述 两两交换链表中的节点 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。...递归的终止条件是链表中没有节点,或者链表中只有一个节点,此时无法进行交换。...如果链表中至少有两个节点,则在两两交换链表中的节点之后,原始链表的头节点变成新的链表的第二个节点,原始链表的第二个节点变成新的链表的头节点。链表中的其余节点的两两交换可以递归地实现。...在对链表中的其余节点递归地两两交换之后,更新节点之间的指针关系,即可完成整个链表的两两交换。...再令 temp = node1,对链表中的其余节点进行两两交换,直到全部节点都被两两交换。 两两交换链表中的节点之后,新的链表的头节点是 dummyHead.next,返回新的链表的头节点即可。

    42520
    领券