• linux中的链表


    //include/linux/list.h 
    struct list_head {                     
        
    struct list_head *next, *prev;  
     }; 


    #define LIST_HEAD_INIT(name) { &(name), &(name) }
    #define LIST_HEAD(name) struct list_head name = LIST_HEAD_INIT(name)

    #define INIT_LIST_HEAD(ptr) do { \
        (ptr)
    ->next = (ptr); (ptr)->prev = (ptr); \
    while (0)

    static inline void __list_add(struct list_head * newnode,
                                      
    struct list_head * prev,
                                      
    struct list_head * next)
    {
        next
    ->prev = newnode;
        newnode
    ->next = next;
        newnode
    ->prev = prev;
        prev
    ->next = newnode;
    }

    //添加一个node
    static inline void list_add(struct list_head *newnode, struct list_head *head)
    {
        __list_add(newnode, head, head
    ->next);
    }


    static inline void list_add_tail(struct list_head *newnode, struct list_head *head)
    {
        __list_add(newnode, head
    ->prev, head);
    }

    static inline int list_empty(struct list_head *head)
    {
        
    return head->next == head;
    }

    static inline void __list_del(struct list_head * prev,
                                      
    struct list_head * next)
    {
        next
    ->prev = prev;
        prev
    ->next = next;
    }
    //删除一个node
    static inline void list_del(struct list_head *entry)
    {
        __list_del(entry
    ->prev, entry->next);
        entry
    ->next = entry->prev = 0;
    }

    #define list_for_each_safe(pos, n, head) \
        
    for (pos = (head)->next, n = pos->next; pos != (head); \
            pos 
    = n, n = pos->next)

    #define list_for_each(pos, head) \
        
    for (pos = (head)->next; pos != (head); \
                pos 
    = pos->next)

    #define list_entry(ptr, type, member) \
        ((type 
    *)((char *)(ptr)-(unsigned long)(&((type *)0)->member)))

    /*******************************
    **指针ptr指向结构体type中的成员member;
    **通过指针ptr,返回结构体type的起始地址
                type

            |----------|
            |           |
            |           |
            |----------|
     ptr-->| member --|
            |----------|
            |              |
            |              |
            |----------| 
    *******************************
    */

    //test_list.c

    #include 
    <stdio.h>
    #include 
    <stdlib.h>

    //#include 
    "ilist.h"


    struct my_list{
        
    struct list_head list;
        
    char value[10]; 
    };

    int main(int argc, char **argv){
        
        
    struct my_list *tmp;
        
    struct list_head *pos, *q;
        unsigned 
    int i;
        
        
    struct my_list mylist;
        INIT_LIST_HEAD(
    &mylist.list); /*初始化链表头*/
        
        
    /* 给mylist增加元素 */
        
    for(i=3; i!=0--i){
            tmp
    = (struct my_list *)malloc(sizeof(struct my_list));
            
            
    /* 或者INIT_LIST_HEAD(&tmp->list); */
            printf(
    "enter value:");
            scanf(
    "%s", tmp->value);
            
            
            list_add(
    &(tmp->list), &(mylist.list));
            
    /* 也可以用list_add_tail() 在表尾增加元素*/
        }
        printf(
    "\n");
        
        printf(
    "traversing the list using list_for_each()\n");
        list_for_each(pos, 
    &mylist.list){
            
        
    /* 在这里 pos->next 指向next 节点, pos->prev指向前一个节点.这里的节点是
            struct my_list类型. 但是,我们需要访问节点本身,而不是节点中的list字段,
            宏list_entry()正是为此目的。
    */     
            
        tmp
    = list_entry(pos, struct my_list, list);
        printf(
    "%s ", tmp->value);
        }
        printf(
    "\n");


        printf(
    "deleting the list using list_for_each_safe()\n");
        list_for_each_safe(pos, q,
    &mylist.list){
            tmp
    = list_entry(pos, struct my_list, list);
            printf(
    "%s ", tmp->value);
            list_del(pos);
            free(tmp);
        }
    }
  • 相关阅读:
    Springboot构建问题集
    常用算法解析技巧总结
    Linux、Docker安装Nginx
    MySQL查询语句报错 sql_mode=only_full_group_by 问题
    MySQL按周统计 WEEK 实例
    IDEA注册码分享
    Mock测试接口
    Maven常用命令
    js中的for循环,循环次数会多出一次。当循环到最后一个的时候,循环还会继续,并且此时i就变成remove?
    vue .sync的理解
  • 原文地址:https://www.cnblogs.com/hustcat/p/1504630.html
Copyright © 2020-2023  润新知