内核链表的简介

以下内容源于朱有鹏嵌入式课程的学习与整理,如有侵权请告知删除。

一、内核链表的设计思路

1、普通链表的数据区域的局限性

如果链表节点要存储一个int类型的数据,可以在数据区域定义int data。但是实际编程中,链表的节点不会这么简单,而是复杂多样的。

实际项目中的链表,往往把数据区封装为一个结构体。链表解决的问题是多样的,因此数据区对应的结构体的构成也是多样的,我们无法通过一套泛性的、普适的操作函数来访问所有的链表,这意味着我们要给每个链表都写一套链表的操作函数(节点创建、插入、删除、遍历等)。

2、内核链表的设计思路

经过分析发现,不同的链表的操作方法是相同的,数据区域的操作有所不同而已。于是可以把所有链表操作方法里共同的部分提取出来,用一套标准方法实现,然后让具体链表的实现者去处理不同的部分。

内核在include/linux/list.h文件中定义了一个纯链表(没有数据区域,只有前后向指针),以及纯链表的各种操作函数(节点创建、插入、删除、遍历等)。

这个纯链表本身没有任何用处,它的用法是给我们具体链表作为核心来调用。

二、内核链表的操作函数

内核链表的节点创建、删除、遍历,略。

 

三、内核链表的使用实践

内核链表只有纯链表,没有数据区域,怎么使用?

使用方法是将内核链表作为结构体的一个成员内嵌进去。这类似于公司收购,实现被收购公司的功能。这里面要借助container_of宏。

举例如下。

#include <linux/list.h>struct driver_info
{int data;
};// driver结构体用来管理内核中的驱动
struct driver
{char name[20];				// 驱动名称int id;						// 驱动id编号struct driver_info info;	// 驱动信息struct list_head head;		// 内嵌的内核链表成员
};struct driver2
{char name[20];				// 驱动名称int id;						// 驱动id编号struct driver_info info;	// 驱动信息//struct list_head head;		// 内嵌的内核链表成员struct driver *prev;struct driver *next;
};

分析driver结构体,可知前三个成员都是数据区域成员(之前简化为int data),第4个成员是一个struct list_head类型的变量(它就是一个纯链表)。本来driver结构体没有链表,也无法用链表来管理。但是driver结构体内嵌的head成员是一个纯链表,所以driver结构体通过head成员扩展了链表的功能。

driver结构体通过内嵌的方式扩展链表成员,其好处不只是有了一个链表成员,关键是可以通过利用list_head本身事先实现的链表的各种操作方法来操作head。最终,我们可以通过遍历head结构体变量来实现driver结构体的遍历。而且,遍历head结构体变量的函数在list.h文件中已经写好,内核去遍历driver结构体时就不用重复去写。

通过操作head来操作driver,实质上就是通过操作结构体的某个成员变量来操作整个结构体变量。这要借助container_of宏,具体见宏定义函数container_of的解释_天糊土的博客。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/461194.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

框架模式和设计模式的区别

框架模式和设计模式的区别有很多程序员往往把框架模式和设计模式混淆&#xff0c;认为MVC是一种设计模式。实际上它们完全是不同的概念。[7]框架、设计模式这两个概念总容易被混淆&#xff0c;其实它们之间还是有区别的。框架通常是代码重用&#xff0c;而设计模式是设计重用&a…

netbeans搭建安卓开发环境

2019独角兽企业重金招聘Python工程师标准>>> NetBeans 上开发 Android 应用程序需要安装一个 Android SDK 和针对 NetBeans 的 Android 开发插件 下载并安装 Android SDK 下载 Android SDK 解压后运行 tools\android.bat update sdk 进行升级&#xff0c;根据所选内…

Linux设备驱动模型4——基于平台总线的LED驱动实践

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 参考博客 platform总线驱动代码分析 平台设备与平台驱动的注册_天糊土的博客-CSDN博客 一、有driver无device 本节把之前的LED驱动源码改写成平台总线制式&#xff0c;先实现platform_driver。 1、…

StringIO类的用途

import StringIO as SIOs1 "Hello" print id(s1) s2 "Hello" s1 print id(s2) sp SIO.StringIO() sp.write("Hello") print sp.getvalue() print id(sp) sp.write("Leon") print sp.getvalue() print id(sp) exit() 主要进行字符串…

VS2010皮肤控件介绍

在我们平时使用的各种工具中&#xff0c;如QQ&#xff0c;迅雷&#xff0c;以及各种空间等&#xff0c;都提供了一些换肤功能&#xff0c;可以让我们选择各种我们喜欢的界面。本文就对VS中常用的窗口程序做一个简单的换肤&#xff0c;利用一个dll文件来进行实现。 首先我们要加…

mimemultipart java_最佳实践 – 发送javamail mime multipart电子邮件和gmail

我有一个Tomcat应用程序需要发送确认电子邮件等。我已经用Javamail(mail.jar)编写了电子邮件发送多部分文本/ HTML电子邮件。我基于Java EE示例的代码。我在本地服务器上使用SMTP MTA。它的作品很棒在Outlook中&#xff0c;我看到了HTML版本。如果我将其拖动到Outlook垃圾邮件文…

framebuffer驱动详解0——framebuffer的简介

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、framebuffer的简介 1、framebuffer的含义 framebuffer的中文意思是“帧缓冲”&#xff0c;简称fb。 2、fb是虚拟的字符设备 fb是内核虚拟的一个字符设备&#xff0c;即它是用代码构建出来的&…

Linux下Chromium使用flash的办法

环境说明:系统: CentOS 6.5 X64很简单&#xff0c;主要原因是在启动Chromium的时候指定了自有的Flash&#xff0c;我们可以在启动参数上去除指定的Flash&#xff01;sudo vim /usr/bin/chromium-browserCHROMIUM_RHEL_FLAGS"--enable-plugins --enable-extensions --ena…

ie7浏览器传输中文的问题

调用jquery的$.get()(此方法应该的对字符串进行了编码)向服务器发送中文字符串时 ie7浏览器会在后面加一个空格&#xff08;服务器接收时还应该进行解码encode("utf-8").strip()再去空格&#xff09;转载于:https://www.cnblogs.com/aveenzhou/archive/2013/04/09/30…

MySQL和Mariadb都启动不了了_linux centos7mariadb安装成功启动不了 解决思路

查看系统日志/var/log/mariadb/mariadb.log190313 14:31:03 InnoDB: Database was not shut down normally!InnoDB: Starting crash recovery.InnoDB: Reading tablespace information from the .ibd files...InnoDB: Restoring possible half-written data pages from the dou…

framebuffer驱动详解1——应用层编程实践

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、步骤总结 步骤1&#xff1a;打开设备文件 步骤2&#xff1a;获取设备信息 步骤3&#xff1a;mmap函数做映射 步骤4&#xff1a;填充framebuffer 二、步骤分析 1、打开设备文件 设备文件为/dev…

(转)API SOCKET基础(一) TCP建立连接并通信

写这篇日志&#xff0c;并不是要记录令人眼前一亮的算法&#xff0c;只是为了本人健忘的脑袋做一点准备。 要进行网络通信编程&#xff0c;就要用到socket&#xff08;套接字&#xff09;&#xff0c;下面以TCP为例展示如何利用socket通信。 要 进行socket编程&#xff0c;首先…

5shift shell

echo offcopy %systemroot%\system32\taskmgr.exe %systemroot%\system32\sethc.execopy %systemroot%\system32\taskmgr.exe %systemroot%\system32\dllcache\sethc.exepause转载于:https://www.cnblogs.com/upshania/p/3817258.html

java 线程转储_获取Java线程转储的常用方法(推荐)

1. 线程转储简介线程转储(Thread Dump)就是JVM中所有线程状态信息的一次快照。线程转储一般使用文本格式, 可以将其保存到文本文件中, 然后人工查看和分析, 或者使用工具/API自动分析。Java中的线程模型, 直接使用了操作系统的线程调度模型, 只进行简单的封装。线程调用栈, 也称…

framebuffer驱动详解2——fb驱动框架分析(核心层)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 一、前言 framebuffer驱动框架包括以下两部分&#xff1a; 1、内核开发者实现的部分&#xff08;核心层&#xff09; rootubuntu:省略部分路径/x210_kernel/drivers/video# ls *.o built-in.o …

Oracle conn 协议适配器错误解决

Oracle conn 协议适配器错误 --解决方法C:\Documents and Settings\administrator>set oracle_sidmyoracleC:\Documents and Settings\administrator>sqlplus /nologSQL*Plus: Release 10.2.0.1.0 - Production on 星期三 12月 26 09:47:16 2012Copyright (c) 1982, 2005…

jquery ajax 文本丢失加号和连接号的问题

因为采用data:字符串这种形式&#xff0c;和&是jquery分隔参数的分隔符&#xff0c;所以会丢失&#xff0c;解决方法就是把text文本中的和&替换掉&#xff0c;用js里面的encodeURIComponent编码&#xff0c;为了省事&#xff0c;直接写出编码替换.. function FixJqText…

python给定一个整数n、判断n是否为素数_输入一个大于3的整数n,判断它是否为素数...

#include //让n被i除(i的值从2到n-1)int main(){int n,i;printf("please enter a integer number,n?");scanf("%d",&n);for(i2;i<n-1;i)if(n%i0) break;if(i",n);else printf("%d is a prime number.",n);return 0;}**************…

kernel移植——修改内核的启动logo

以下内容源于朱有鹏嵌入式课程的学习&#xff0c;如有侵权请告知删除。 参考博客 http://blog.csdn.net/ultraman_hs/article/details/54988168 一、自定义内核启动logo 步骤一&#xff1a;安装工具包 在命令行中输入以下内容 sudo apt-get install netpbm 步骤二&#xff1a;…

编译Ngnix遇到的问题,查看程序依赖的库文件

要点:ldd 可以读取每个可以运行的程序依赖的 so 文件。 编译的时候提示需要Openssl库. 查看本机,已经安装了openssl 查看编译报错文件,查找Openssl所依赖的库 more objs/autoconf.err 查看openssl所依赖的库文件 ldd /usr/bin/openssl ldd –u /usr/bin/openssl objdump -x ob…