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

list_for_each_entry_safe 简介

list_for_each_entry_safe 是 Linux 内核中用于遍历链表的一个宏,特别适用于在遍历过程中可能需要删除链表节点的场景。它的设计保证了在删除当前节点时,不会影响后续节点的访问,从而实现安全的遍历。

定义

#define list_for_each_entry_safe(pos, n, head, member) \for (pos = list_entry((head)->next, typeof(*pos), member), \n = list_entry(pos->member.next, typeof(*pos), member); \&pos->member != (head); \pos = n, n = list_entry(n->member.next, typeof(*n), member))

参数说明

  1. pos: 当前遍历到的链表节点对应的结构体指针。
  2. n: 临时指针,用于保存下一个节点的位置。
  3. head: 链表头节点的地址。
  4. member: 链表节点在结构体中的成员名。

工作原理

  • list_for_each_entry_safe 在每次循环中,使用 n 保存当前节点的下一个节点地址。
  • 即使在循环中删除了当前节点(由 pos 指向),由于 n 已经保存了下一个节点的位置,后续遍历可以继续进行而不受影响。

使用场景

主要用于需要在遍历链表的同时删除链表节点的场景。例如:

示例代码:遍历并删除链表节点

struct my_list {int data;struct list_head list;
};struct my_list *pos, *tmp;// 遍历并删除链表中的所有节点
list_for_each_entry_safe(pos, tmp, &head, list) {printk(KERN_INFO "Data: %d\n", pos->data);list_del(&pos->list); // 从链表中删除当前节点kfree(pos);           // 释放内存
}

示例代码:只遍历链表

如果只是遍历而不删除,可以使用 list_for_each_entry

struct my_list *pos;// 遍历链表
list_for_each_entry(pos, &head, list) {printk(KERN_INFO "Data: %d\n", pos->data);
}

list_for_each_entry 的区别

  • list_for_each_entry: 用于普通遍历,不支持安全删除操作。
  • list_for_each_entry_safe: 在遍历过程中允许安全地删除当前节点。

总结

list_for_each_entry_safe 是 Linux 内核中处理双向链表的一种高级工具,适合需要在遍历过程中修改或删除链表元素的场景。它通过额外的临时指针确保操作安全,不会破坏链表结构[1][2][3].

Citations:
[1] https://developer.aliyun.com/article/375545
[2] https://blog.csdn.net/Wang20122013/article/details/112307416
[3] http://www.korantli.com.cn/linux/nei-he-lian-biao/
[4] https://www.cnblogs.com/yangguang-it/p/11667772.html
[5] https://blog.csdn.net/weixin_42645653/article/details/126560076
[6] https://www.cnblogs.com/zhoug2020/p/4972923.html
[7] https://www.51cto.com/article/695735.html
[8] https://juejin.cn/post/7091220406312370213

http://www.lryc.cn/news/537135.html

相关文章:

  • 微软AutoGen高级功能——Memory
  • 【鸿蒙开发】第三十六章 状态管理 - V1V2混用和迁移指导
  • 轮子项目--消息队列的实现(3)
  • 一文深入了解DeepSeek-R1:模型架构
  • 秘密信息嵌入到RGB通道的方式:分段嵌or完整嵌入各通道
  • Ai人工智能的未来:趋势、挑战与机遇
  • 理解WebGPU 中的 GPUDevice :与 GPU 交互的核心接口
  • Java 设计模式之桥接模式
  • 机器学习(李宏毅)——GAN
  • QT无弹窗运行和只允许运行一个exe
  • C++ STL 容器
  • 开源赋能,智造未来:Odoo+工业物联网,解锁智能工厂新范式——以真实案例解读制造业数字化转型的降本增效密码
  • CTF-WEB: 利用iframe标签利用xss,waf过滤后再转换漏洞-- N1ctf Junior display
  • K8s组件
  • python面试题
  • AOS安装及操作演示
  • 蓝桥杯单片机组第十三届初赛试题-程序题(第2批)
  • 企业级高可用 Kubernetes 实践:基于青云 LB 搭建容灾与负载均衡集群全攻略
  • Python Pandas(11):Pandas 数据可视化
  • 【练习】图论
  • 【RAG落地利器】Weaviate、Milvus、Qdrant 和 Chroma 向量数据库对比
  • 今日AI和商界事件(2025-02-14)
  • 【大语言模型】最新ChatGPT、DeepSeek等大语言模型助力高效办公、论文与项目撰写、数据分析、机器学习与深度学习建模等科研应用
  • spring6(完结)
  • Kubernetes (k8s) 常用指令速查表
  • DeepSeek教unity------MessagePack-05
  • Kotlin 优雅的接口实现
  • 新的面试题CSS
  • DeepSeek R1打造本地化RAG知识库
  • 聚铭网络入围2025年度江苏省政府采购信息安全设备协议供货名单