当前位置: 首页 > news >正文

内核数据结构用法(2)list

list

在 Linux 内核中,链表操作是通过一组宏和函数来实现的,这些操作通常用来管理和遍历链表。以下是一些常用的链表函数和宏的具体用法。

1. 定义链表节点

首先,你需要定义一个包含 struct list_head 的结构体:

#include <linux/list.h>

struct my_node {
    int data;
    struct list_head list;  // 链表节点
};

2. 初始化链表

使用 INIT_LIST_HEAD函数初始化链表头:

INIT_LIST_HEAD(&mng->active_list);

3. 添加节点

可以使用以下函数来添加节点:

  • 在链表头添加
struct my_node *new_node = kmalloc(sizeof(struct my_node), GFP_KERNEL);
new_node->data = 42;
list_add(&new_node->list, &my_list);  // 添加到链表头
  • 在链表尾添加
list_add_tail(&new_node->list, &my_list);  // 添加到链表尾

4. 遍历链表

可以使用 list_for_eachlist_for_each_entry 宏遍历链表:

struct my_node *pos;
list_for_each_entry(pos, &my_list, list) {
    printk("Data: %d\n", pos->data);
}

若要遍历删除节点,则要使用list_for_each_entry_safe

5. 删除节点

使用 list_del 删除链表中的节点:

list_del(&node_to_delete->list);  // 从链表中删除节点
kfree(node_to_delete);  // 释放节点内存

6. 检查链表是否为空

可以使用 list_empty 函数检查链表是否为空:

if (list_empty(&my_list)) {
    printk("List is empty\n");
}

list_entry 宏用于将链表节点指针转换为包含该节点的结构体指针。

list_first_entry 宏用于获取链表第一个节点的指针,并转换为包含该节点的结构体指针。

http://www.dtcms.com/a/27179.html

相关文章:

  • 开源模型应用落地-qwen2-7b-instruct-LoRA微调模型合并-LLaMA-Factory-单机多卡-RTX 4090双卡(六)
  • halcon激光三角测量(二十三)inspect_3d_surface_intersections
  • Laravel从入门到上云
  • Deepseek整合SpringAI
  • JVM 类加载器深度解析(含实战案例)
  • MySQL 安装过程记录以及安装选项详解
  • 【C++八股】内存对⻬
  • UniApp 中 margin 和 padding 属性的使用详解
  • vue3项目上线配置 nginx代理
  • hive如何导出csv格式文件
  • Bootstrap CSS 概览
  • postgres源码学习之登录
  • Qt中利用httplib调用https接口
  • Android今日头条的屏幕适配方案
  • c++进阶———继承
  • I2C学习笔记-软件模拟I2C
  • 【分治法】线性时间选择问题
  • 力扣-二叉树-235 二叉搜索树的最近公共祖先
  • HarmonyOS全栈开发指南:从入门到精通,构建万物智联的未来生态(四)
  • C++(23):为类成员函数增加this参数
  • HTTP 和RESTful API 基础,答疑
  • 【JavaScript】实战案例-放大镜效果、图片切换
  • 【龙智】Confluence到期日提醒插件Data Center v1.8.0发布:Confluence 9兼容、表格提醒强化,Slack通知升级
  • 汽车免拆诊断案例 | 2013 款奔驰 S300L 车起步时车身明显抖动
  • SpringBoot高级-底层原理
  • Sponge VS Spring:新兴力量与行业标准的碰撞
  • 三、数据治理应用开发整体架构
  • 【部署优化篇四】《DeepSeek移动端优化:CoreML/TFLite实战对比》
  • TypeScript跟js,es6这些的区别
  • mysql实现原理 - 字符集和排序规则