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

linux通用链表

Linux中设计了一种适合于各种类型数据域都可以使用的通用型链表: struct list_head { struct list_head *prev, *next; }; 摒弃掉数据域,只保留头尾指针...内核链表 链表的主要意义就是将分散地址的数据域通过指针排列成有序的队列。因此数据域是链表不可或缺的一部分,但是在实际使用中需要不同类型的数据域,因此也就限制了链表的通用。...Linux中在声明中抛弃了数据域,也就解决掉了这一问题。 原理 Linux使用链表的方法:使用时,自定义结构体包含数据域+链表结构体。...即让内部链表成员与其他链表成员构建成双链表,实现遍历寻址,然后通过链表成员找到包含该成员的结构体首地址。 ?...「linux实现获取结构体首地址:」 #define list_entry(ptr, type, member) \ ((type *)((char *)(ptr)-(unsigned long)(&(

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

    数据结构之链表使用链表实现栈以及使用链表实现队列

    所以对于链表来说,可以将链表的头部当作栈顶,用链表做为栈的底层实现来实现一个栈。 创建一个栈的接口,可以使用数组的方式或者链表的方式进行实现栈的功能哦!...,使用链表实现队列。   ...2)、对于使用数组来实现队列的时候,也遇到类似问题,需要改进数组实现队列的方式,所以产生了循环队列,对于链表也存在同样的问题,我们不能直接使用之前的链表结构,需要引入改进该链表,由此引入了尾指针。...4)、所以,对于链表来说,在head端和tail端添加节点都是非常容易的。 ? 3.1、考虑,如何在tail端删除一个节点。链表新增尾指针,使用链表实现队列。   ...4)、注意,由于对这个链表的操作全都在链表的一侧完成,也就是head端或者tail端完成,就不使用虚拟头节点了,因为不牵扯到对链表的中间的一个元素进行插入或者删除这样的操作,所以也就没有必要统一对链表的中间元素进行操作和对链表两侧的元素进行操作

    81730

    C 链表 - linux 如何实现

    想起前段时间, 看到FreeRTOS提供的链表处理方式(《 FreeRTOS 任务调度 List 组织 》), 将链表结构定义和实际使用时具体节点数据内容分开定义, 供系统各个模块使用。...查看linux的源码, 发现linux中也为我们提供了相似的实现(源码), 把一些共性统一起来。 类是 python 中for_each处理,有些意思。...linux 下的链表定义在文件 include/linux/types.h, 采用的是双向列表 struct list_head { struct list_head *next, *prev;...list 利用这个定义, 我定义了一个自己的list数据结构, 并copy了一些接口实现,感受下,linux 是如何管理链表的。...int_node, list); printf("%d ", pnode->val); } printf("\n"); return 0; } 虽然比较简单,记录下,学习linux

    2.7K30

    linux内核源码 -- list链表

    linux kernel中的list估计已经被各位前辈们写烂了,但是我还是想在这里记录一下; linux kernel里的很多数据结构都很经典, list链表就是其中之一 本篇要介绍的内容: list...的定义 list提供的操作方法 注意事项 使用实例 ---- List 所在文件: List的所有操作可以在 include/linux/list.h找到; List head的定义可以在 include.../linux/types.h找到; 定义 实际上这就是一个双向循环链表, 且有一个头指针 list head的定义: struct list_head { struct list_head *next..., *prev; }; 这个定义中只有前向和后向指针,没任何的数据部分, 那我们基本上就知道了, 它不是被单独使用的,而是把它嵌入到用户定义的struct中, 将用户定义的数据结构串起来,作成list;...member) \ container_of(ptr, type, member) 一堆宏定义, 用来各种遍历, 获取entry 注意事项 只说一个,就是多线程操作同一个list, 还是需要加锁 使用实例

    2.4K10

    Linux 内核通用链表学习小结

    描述 在linux内核中封装了一个通用的双向链表库,这个通用的链表库有很好的扩展性和封装性,它给我们提供了一个固定的指针域结构体,我们在使用的时候,只需要在我们定义的数据域结构体中包含这个指针域结构体就可以了...传统的链表结构 struct node{ int key; int val; node* prev; node* next; } linux 内核通用链表库结构 提供给我们的指针域结构体...(type *)( (char *)__mptr - offsetof(type,member) );}) #define offsetof(s,m) (size_t)&(((s *)0)->m) 使用方式...反推结构体首地址 举个例子 这个例子包括简单的增、删、遍历 #include #include #include <linux...内核提供的这个通用链表库里面还有很多其他的接口,这里没有详细的一一举例,有兴趣的可以自己去看看,在源码包 include/linux/list.h 文件里面,不过通过阅读一些源代码确实对我们也有很大的提高

    1.3K21

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

    在上一小节中关于在链表中头部添加元素与在其他位置添加元素在逻辑上有所差别,这是由于我们在给链表添加元素时需要找到待添加元素位置的前一个元素所在的位置,但对于链表头来说,没有前置节点,因此在逻辑上就特殊一些...为了针对头结点的操作方式与其他方式一致:接下来我们就一步一步引入今天的主题--使用虚拟头结点。 首先来看看之前的节点结构--第一个是头结点 ?  ...则dummyHead节点变为了0这个节点(头结点)的前置节点,则现在所有节点都有了前置节点,在逻辑可以使用统一的操作方式。...size = 0; } (3)改进之前的add(int index,E e)方法,之前对在头结点添加元素单独做了处理(if-else判断),如下: 1 //在链表的index(0--based...void addLast(E e) { 86 add(size, e); 87 } 88 } 本小节着重介绍了虚拟头节点的使用,若您觉得本文还行、还过得去,麻烦给个推荐吧,谢谢

    1.8K20

    链表实现及使用

    一、概念 历史拉链表,就是记录一个事务从开始一直到当前状态的所有变化的信息,拉链表可以避免按每一天存储所有记录造成的海量存储问题,同时也是处理缓慢变化数据的一种常见方式。...而用拉链表存储,每日只向表中新增和变化的数据量,每日不过20万条, 储存2年也只需要 2 x 365 * 200000 = 146000000 (1.46以)存储空间。...character varying, create_date date, update_date date ) distribute by hash(user_id); –创建目标拉链表...—————— 1003 | rose | 120 | 13000000003 | 2019-11-12 00:00:00 | 2999-12-31 00:00:00 –拉链表中...eleven | 120 | 13000000004 | 2019-11-13 00:00:00 | 2999-12-31 00:00:00 –更新后的数据 (5 rows) –拉链表使用

    65020

    Java链表的基本使用

    链表是一种根据元素节点逻辑关系排列起来的一种数据结构。...利用链表可以保存多个数据,这一点类似于数组的概念,但是数组本身有一个缺点—— 数组的长度固定,不可改变,在长度固定的情况下首选的肯定是数组,但是在现实的开发之中往往要保存的内容长度是不确定的,那么此时就可以利用链表这样的结构来代替数组的使用...链表是一种最为简单的数据结构,它的主要目的是依靠引用关系来实现多个数据的保存。 下面是定义一个简单的类用来保存节点关系,并将所有节点链接起来。...例子1: //每一个链表实际上就是由多个节点组成的 class Node { private String data; //用于保存数据 private Node next;...if(this.root == null ){ // 如果链表还没有任何节点,就添加第一个节点作为根节点 this.root = newNode;

    47210

    Linux C 数据结构 ->单向链表

    简介   链表Linux 内核中最简单,最普通的数据结构。...链表是一种存放和操作可变数量元素(常称为节点)   的数据结构,链表和静态数组的不同之处在于,它所包含的元素都是动态创建并插入链表的,在编译   时不必知道具体需要创建多少个元素,另外也因为链表中每个元素的创建时间各不相同...根据它的特性,链表可分为:单链表,双链表,单向循环链表和双向循环链表,今天总结记录的就是   最简单的单链表,   1.1 节点类型描述   1 typedef struct node_t {   ...,我们如何表现空链表呢?...链表基本运算的相关"算法"操作 or 操刀(~烹羊宰牛且为乐,会须一饮三百杯~)   链表的运算除了上面的创建空链表,还有数据的插入,删除,查找等函数,链表的运算有各种实现方   法,如何写出一个高效的

    1.1K00

    Linux C语言链表详细分析

    链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入节点。链表都有一个头指针,一般以head来表示,存放的是一个地址。...链表中的节点分为两类,头结点和一般节点,头结点是没有数据域的。链表中每个节点都分为两部分,一个数据域,一个是指针域。...作为有强大功能的链表,对他的操作当然有许多,比如:链表的创建,修改,删除,插入,输出,排序,反序,清空链表的元素,求链表的长度等等。   ...初学链表,一般从单向链表开始   --->NULL   head   这是一个空链表。   ---->[p1]---->[p2]......初始化一个链表,n为链表节点个数。

    1.1K20

    Linux C语言链表你学会了吗?

    链表可以动态的进行存储分配,也就是说,链表是一个功能极为强大的数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入节点。链表都有一个头指针,一般以head来表示,存放的是一个地址。...链表中的节点分为两类,头结点和一般节点,头结点是没有数据域的。链表中每个节点都分为两部分,一个数据域,一个是指针域。...作为有强大功能的链表,对他的操作当然有许多,比如:链表的创建,修改,删除,插入,输出,排序,反序,清空链表的元素,求链表的长度等等。   ...初学链表,一般从单向链表开始 --->NULL   head   这是一个空链表。   ---->[p1]---->[p2]......初始化一个链表,n为链表节点个数。

    1.3K20

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

    概要 本文对双向链表进行探讨,介绍的内容是Linux内核中双向链表的经典实现和用法。其中,也会涉及到Linux内核中非常常用的两个经典宏定义offsetof和container_of。...这两个宏最初是极客写出的,后来在Linux内核中被推广使用。...Linux中双向链表的经典实现 1.Linux中双向链表介绍 Linux双向链表的定义主要涉及到两个文件: include/linux/types.h include/linux/list.h Linux...中双向链表使用思想 它是将双向链表节点嵌套在其它的结构体中;在遍历链表的时候,根据双链表节点的指针获取"它所在结构体的指针",从而再获取数据。...3.Linux中双向链表使用示例 双向链表代码(list.h): 1 #ifndef _LIST_HEAD_H 2 #define _LIST_HEAD_H 3 // 双向链表节点 4 struct

    2.6K30

    Redis链表使用场景和使用示例

    图片Redis链表使用场景包括但不限于以下几种:1. 消息队列:Redis链表可以作为一个轻量级的消息队列,用来实现发布/订阅模式或延迟任务处理。...排行榜:Redis链表可以用于实现排行榜功能,将排名和分数作为链表节点的数据,按分数进行排序。对于需要频繁查询和更新的排行榜功能,Redis链表能够提供高效的性能。...可以将用户ID和点赞数量作为链表节点的数据,将用户按照点赞数量从高到低排序,用户每次点赞时更新链表中对应节点的点赞数量。3....分页查询:Redis链表可以用于分页查询功能,将需要分页的数据按序插入链表中,通过获取链表的片段来实现分页查询。例如,假设有一个新闻资讯网站,需要在首页展示最新的新闻列表并支持分页浏览。...可以将新闻按时间顺序作为链表节点的数据,每次在链表的头部插入最新的新闻,在首页展示链表的片段,通过获取链表的下一页或上一页进行分页操作。

    33051

    一文搞懂 Linux 内核链表(深度分析)

    Linux 内核中使用最多的数据结构就是链表了,其中就包含了许多高级思想。 比如面向对象、类似C++模板的实现、堆和栈的实现。 1....如果去掉前驱指针,就是单循环链表。 ? 2. 内核链表Linux内核中使用了大量的链表结构来组织数据,包括设备列表以及各种功能模块中的数据组织。...这些链表大多采用在[include/linux/list.h]实现的一个相当精彩的链表数据结构。事实上,内核链表就是采用双循环链表机制。 内核链表有别于传统链表就在节点本身不包含数据域,只包含指针域。...当 list1 被挂接到 list2 之后,作为原表头指针的 list1 的next、prev仍然指向原来的节点,为了避免引起混乱,Linux提供了一个list_splice_init()函数.该函数在将...总结 本文详细分析了 linux 内核 中的双链表结构,以图文的方式旨在帮助大家理解。

    8.2K77

    链表使用内部类Node来实现

    链表使用内部类Node来实现的: 数组+链表(散列表) 其实就是用于解决哈希冲突使用的一个拉链法方法。...在数据结构中,我们处理hash冲突常使用的方法有:开发定址法、再哈希法、链地址法、建立公共溢出区。而HashMap中处理hash冲突的方法就是链地址法。...但是这样子的话,如果使用了很久,HashMap存储的元素越来越多,那么链表就会变的很长,那么性能就会下降很多(因为链表不适合查找元素,每次查找元素都要从头开始遍历)。...于是在1.8的时候进行了改进,使用到了红黑树(红黑树是一个自平衡的二叉查找树,查找效率是非常高,时间复杂度仅为O(logN))。...在HashMap中,链表转化成红黑树的条件是当链表长度大于8且数组(桶)的个数要大雨等于64个时,才可以将链表转化成红黑树,它们在源码中的定义如下: static final int MIN_TREEIFY_CAPACITY

    29920
    领券