目录

list链表的使用

目录

list链表的使用

  1. list_for_each_entry_safe
list_for_each_entry_safe(pos, n, head, member)

pos:指向当前链表节点的指针,类型为链表元素的结构体类型。 n:指向下一个链表节点的指针,类型与 pos 相同,用于临时保存下一个节点,防止在删除当前节点后丢失链表信息。 head:链表的头节点。 member:链表节点在结构体中的成员名称。 2. list_for_each_entry

链表遍历过程的一个封装
#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:链表节点中链接前后节点的成员变量名 3. list_entry 用于获取包含某个成员变量的结构体指针。

#define list_entry(ptr,type,member)\
container_of(ptr,type,member)

ptr:包含成员变量的指针 type:包含成员变量的结构体类型 member:成员变量的名称 4. 例子

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);
}