C语言实现链表之双向链表(一)头文件
前面已经出过一个单向链表的系列,这里给出双向链表的实现,这一系列的实现与单向链表有很多类似之处,大家可以参考单向链表的系列。
单向链表的系列(一)的链接是:点击打开链接
双向链表主要就是加上了一个前向指针其他的并没有太多变化,直接进入正题。
本次设计的链表操作库主要包含三个文件,分别是:MyList_Bidirection.h---头文件、MyList_Bidirection.c---实现文件以及ListTestTop.c---测试文件。本篇文章先给出本次双向链表库的头文件,概览一下基本的结构形式和实现的功能。
/*
*****************************************************************************************
* UART Block
*
* (c) Copyright
* All Rights Reserved
*
* Filename : MyList_Bidirection.h
*
* Function : 双向非循环链表结构定义及操作函数集声明
*
* History : 1. wangyi 2015-4-19 17:47 Version 1.0 creat
*
*****************************************************************************************
*/
#ifndef _MYLIST_
#define _MYLIST_
// C中的布尔变量定义
typedef enum{FALSE, TRUE}C_Bool;
// 链表数据定义
typedef struct MyListData
{
char cName[20];
int iAge;
}MyListData;
// 链表结点定义
typedef struct MyListNode
{
MyListData sNodeData;
struct MyListNode* pPrevNodeAddr;
struct MyListNode* pNextNodeAddr;
}MyListNode;
// 链表操作函数声明
/*==============================================================================
* 操作 :为链表的结点分配内存,并初始化数据元素
* 操作前:pListNode为链表的结点
* 操作后:返回分配内存并初始化后的结点,操作失败返回NULL
==============================================================================*/
MyListNode* MallocMemInitNode(MyListNode* pListNode);
/*===========