0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Linux内核的链表数据结构

CHANBAEK 来源:头条号科G栈 作者:头条号科G栈 2023-03-24 11:34 次阅读

Linux内核实现了自己的链表数据结构,它的设计与传统的方式不同,非常巧妙也很通用。

我们先看一下传统的定义

struct xxx{
    void * p;
    struct xxx * next,* prev;
}

这种方式将数据和链表指针定义在一起,整个链表也是通过整个结构体连接起来的。 这种链表不具有通用性,换一个不同的结构体需要重新定义。

内核使用了不同的方式,它把链表的指针抽象出来,独立定义。

struct list_head{
     struct list_head *next, *prev;
};

使用的时候嵌入到结构体中即可。

这种方式将数据和链表剥离开来,去除了链表和数据的耦合,这样就可以定义统一的接口,使得链表的管理和操作变得非常简洁。

内核在

大家发现一个问题没有,我们如何获得链表所在结构体其他数据呢?

内核使用container_of()函数实现,这个函数能够通过结构体内部成员的地址找到结构体本身的地址,这样就可以通过链表的地址得到数据结构体的地址,然后就可以获得其他数据了。 这些在链表的操作方法中都已经实现了。

链表在内核中非常重要,比如所有进程就是通过链表管理,进程的子进程、兄弟进程也是链表管理,这些在进程描述符中都可以看到。

一个结构中可以包含多个不同的链表节点,分别从属于不同的链表,构成一个错综复杂的网络结构。

小结:

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 内核
    +关注

    关注

    3

    文章

    1309

    浏览量

    39843
  • Linux
    +关注

    关注

    87

    文章

    10988

    浏览量

    206724
  • 数据结构
    +关注

    关注

    3

    文章

    564

    浏览量

    39899
  • 结构体
    +关注

    关注

    1

    文章

    125

    浏览量

    10749
  • 链表
    +关注

    关注

    0

    文章

    80

    浏览量

    10464
收藏 人收藏

    评论

    相关推荐

    数据结构中最简单的链表

    数据结构作为嵌入式工程师必修课程之一,今天,我们就来讲一讲数据结构中最简单的链表,包含链表的初始化、插入和遍历操作。 链表在项目开发中使用的
    发表于 06-13 17:40 250次阅读

    Linux内核链表操作

    Linux内核链表操作本文详细分析了 2.6.x 内核链表结构的实现,并通过实例对每个
    发表于 08-29 11:13

    Linux Kernel数据结构:链表

    Linux Kernel数据结构链表原创 2016年10月20日 22:58:25标签:LINUX/kernel/链表
    发表于 09-25 16:41

    数据结构链表的基本操作

    嵌入式学习基础-数据结构链表的基本操作链表节点采用结构体的方式进行定义,下面是最基础的定义只有一个数据data,*pNext用于指向下一个节
    发表于 12-22 08:05

    Linux内核中的数据结构的一点认识

    大家都知道linux内核是世界上优秀的软件之一,作为一款优秀的软件,其中的许多的设计都精妙之处,十分值得学习和借鉴。今天我们就带大家看一下内核中的数据结构中一点设计。打开
    发表于 04-20 16:42

    OpenHarmony——内核IPC机制数据结构解析

    通信的数据结构,可以在任务间传递消息内容或消息的地址。内核用队列控制块来管理消息队列,同时又使用双向环形链表来管理控制块。队列控制块: 管理具体消息队列的数据块,
    发表于 09-05 11:02

    OpenHarmony——内核IPC机制数据结构解析

    通信的数据结构,可以在任务间传递消息内容或消息的地址。内核用队列控制块来管理消息队列,同时又使用双向环形链表来管理控制块。队列控制块:管理具体消息队列的数据块,
    发表于 09-08 11:44

    算法与数据结构——双向链表

    第三章为算法与数据结构,本文为3.3 双向链表
    的头像 发表于 09-19 17:56 7066次阅读
    算法与<b class='flag-5'>数据结构</b>——双向<b class='flag-5'>链表</b>

    Linux 内核数据结构:位图(Bitmap)

    除了各种链式和树形数据结构Linux内核还提供了位图接口。位图在Linux内核中大量使用。下面的源代码文件包含这些
    发表于 05-14 17:24 3234次阅读

    你知道Linux内核数据结构中双向链表的作用?

    Linux 内核提供一套双向链表的实现,你可以在 include/linux/list.h 中找到。我们以双向链表着手开始介绍
    发表于 05-14 17:27 1756次阅读

    Linux0.11-进程控制块数据结构

    嵌入式Linux中文站收集整理Linux0.11版本内核学习笔记,本文分析了Linux进程控制模块的数据结构
    发表于 05-15 15:22 847次阅读

    什么是栈?数据结构中栈如何实现

    今天放松一下,我们来看看数据结构中的栈,这节的知识点可以说是数据结构中最容易上手的知识点了,其实比起链表,其实链表也有栈和队列的模型,链表
    发表于 04-29 18:25 0次下载
    什么是栈?<b class='flag-5'>数据结构</b>中栈如何实现

    linux内核中llist.h文件中的链表宏讲解

    链表宏在linux内核、鸿蒙内核、rtos和一些开源代码中用的非常多。链表宏是双向链表的经典实现
    的头像 发表于 05-23 12:06 1573次阅读

    Linux内核代码中常用的数据结构有哪些?

    Linux内核代码中广泛使用了数据结构和算法,其中最常用的两个是链表和红黑树。
    发表于 07-20 09:39 320次阅读

    Linux内核中使用的数据结构

    Linux内核代码中广泛使用了数据结构和算法,其中最常用的两个是链表和红黑树。 链表 Linux
    的头像 发表于 11-09 14:24 203次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>内核</b>中使用的<b class='flag-5'>数据结构</b>