linux内核双向循环链表实例

本文详细介绍了双向循环链表的基本概念、结构定义及核心操作函数,包括初始化、插入、删除等,并通过实例展示了链表的应用场景。此外,还探讨了链表中常用的数据结构类型和关键操作技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//list.h

#ifndef _LIST_H
#define _LIST_H
/**
 *内核里的双向循环链表
 *是一个只有指针域而没有数据域的结构
 */

struct list{
    struct list *prev, *next;
};

#define LIST_HEAD_INIT(name) { &(name), &(name) }
#define LIST_HEAD(name) \
    struct list name = LIST_HEAD_INIT(name)
#define offetof(type, member) (unsigned int &((type *)0->member))
#define list_entry(ptr, type, member)({ \
    const typeof(((type *)0)->member) *__mptr = (ptr); \
    (type *)((char *)__mptr - offsetof(type, member));})
#define list_for_each(pos, head) \
    for(pos = (head)->next; pos != (head); pos=pos->next)
/**
 *初始化一个双向循环链表
 */

static inline void INIT_LIST_HEAD(struct list *list)
{
    list->next = list;
    list->prev = list;
}
/**
 *函数名:__list_add
 *插入一个new链表
 */

static inline void __list_add(struct list *new,
             struct list *prev,
             struct list *next)
{
    next->prev = new;
    new->next = next;
    new->prev = prev;
    prev->next = new;
}
/**
 *函数名:list_add_head
 *采用头插法插入一个新的链表
 */

static inline void list_add_head(struct list *new, struct list *head)
{
    __list_add(new, head, head->next);
}
/**
 *函数名:list_add_tail
 *采用尾插法插入一个新的链表
 */

static inline void list_add_tail(struct list *new, struct list *head)
{
    __list_add(new, head->prev, head);
}
/**
 *函数名:__list_del
 *删除一个链表
 */

static inline void __list_del(struct list *prev, struct list *next)
{
    prev->next = next;
    next->prev = prev;
}
/**
 *函数名:list_del
 *删除一个具体的链表
 */

static inline void list_del(struct list *entry)
{
    __list_del(entry->prev, entry->next);
}
#endif

list.c:





/*
 * Copyright (c) 2009-~ Lan Peng
 *
 * This source code is released for free distribution under the terms of the
 * GNU General Public License
 *
 * Author: Lan Peng<lanpeng722@gmail.com>
 * Created Time: 2009年10月29日 星期四 10时43分27秒
 * File Name: list.c
 *
 * Description:
 */


#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include "list.h"
struct mylist{
    int data;
    struct list list;
};

int main(int args, char *argv[])
{
    int i,n;
    struct mylist *tmp, *task;
    struct mylist head;
    struct list *pos;
    INIT_LIST_HEAD(&head.list);
    for(i = 0; i < 10; i++){
        tmp = (struct mylist *)malloc(sizeof(struct mylist));
        tmp->data = i;
        printf("I:%d\n", i);
        list_add_tail(&(tmp->list), &(head.list));//新的链表插入尾部

    }
    printf("\n");
    list_for_each(pos, &(head.list)){//遍历链表

        task=list_entry(pos, struct mylist, list);
        printf("II:%d\n", task->data);
    }
    printf("\n");
    pos = head.list.next;
    n = 3;//删除第n个元素

    for(i = 1; i < n; i++)
        pos = pos->next;
    list_del(pos);//删除链表

    list_for_each(pos, &(head.list)){
        task=list_entry(pos, struct mylist, list);
        printf("III:%d\n", task->data);
    }
    return 0;
}


阅读(477) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值