list链表的使用

  1. list_for_each_entry_safe
c 复制代码
list_for_each_entry_safe(pos, n, head, member)

pos:指向当前链表节点的指针,类型为链表元素的结构体类型。

n:指向下一个链表节点的指针,类型与 pos 相同,用于临时保存下一个节点,防止在删除当前节点后丢失链表信息。

head:链表的头节点。

member:链表节点在结构体中的成员名称。

  1. list_for_each_entry
c 复制代码
链表遍历过程的一个封装
#define list_for_each_entry(pos,head,member)\
    for(pos=list_entry((head)->next,typeof(*pos),member);\
        &pos->member!=(head);\
        pos=list_entry(pos->member.next,typeof(*pos),member))

pos:链表中节点的指针

head:链表的头结点指针

member:链表节点中链接前后节点的成员变量名

  1. list_entry
    用于获取包含某个成员变量的结构体指针。
c 复制代码
#define list_entry(ptr,type,member)\
    container_of(ptr,type,member)

ptr:包含成员变量的指针

type:包含成员变量的结构体类型

member:成员变量的名称

  1. 例子
c 复制代码
struct student{
    int id;
    char name[20];
    struct list_head list;
};
struct list_head student_list;//链表头节点
struct student *stu;
list_for_each_entry(stu,&student_list,list) {
    printf("id:%d,name%s\n",stu->id,stu->name);
}
相关推荐
炽烈小老头8 小时前
【每天学习一点算法 2026/03/08】相交链表
学习·算法·链表
串口哑火达人8 小时前
(六)RT-Thread网络通信--AT组件与ESP8266
c语言·单片机·嵌入式硬件·mcu·物联网
仰泳的熊猫9 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
啊哦呃咦唔鱼10 小时前
LeetCode hot100-15 三数之和
数据结构·算法·leetcode
leluckys10 小时前
算法-链表-二、成对交换两个节点
数据结构·算法·链表
爱编码的小八嘎11 小时前
C语言完美演绎3—8
c语言
Nontee11 小时前
Leetcode Top100答案和解释 -- Python版本(链表)
算法·leetcode·链表
Irissgwe13 小时前
C&C++内存管理
c语言·开发语言·c++·c++内存管理
雾岛听蓝13 小时前
C文件操作与系统IO
linux·c语言·开发语言·经验分享·笔记·算法
随意起个昵称13 小时前
【贪心】选择尽量多的不相交区间
数据结构·算法