目录:
- 代码:
- 分析:
- 汇编:
代码:
DLinkList.h
#ifndef _DLINKLIST_H_
#define _DLINKLIST_H_typedef void DLinkList;
typedef struct _tag_DLinkListNode DLinkListNode;
struct _tag_DLinkListNode
{DLinkListNode* next;//指向下节点DLinkListNode* pre;//前节点
};DLinkList* DLinkList_Create();void DLinkList_Destroy(DLinkList* list);void DLinkList_Clear(DLinkList* list);int DLinkList_Length(DLinkList* list);int DLinkList_Insert(DLinkList* list, DLinkListNode* node, int pos);DLinkListNode* DLinkList_Get(DLinkList* list, int pos);DLinkListNode* DLinkList_Delete(DLinkList* list, int pos);DLinkListNode* DLinkList_DeleteNode(DLinkList* list, DLinkListNode* node);DLinkListNode* DLinkList_Reset(DLinkList* list);DLinkListNode* DLinkList_Current(DLinkList* list);DLinkListNode* DLinkList_Next(DLinkList* list);DLinkListNode* DLinkList_Pre(DLinkList* list);#endif
DLinkList.c
#include <stdio.h>
#include <malloc.h>
#include "DLinkList.h"typedef struct _tag_DLinkList
{DLinkListNode header;//头节点DLinkListNode* slider;int length;
} TDLinkList;DLinkList* DLinkList_Create() //定义创建表函数
{TDLinkList* ret = (TDLinkList*)malloc(sizeof(TDLinkList));if( ret != NULL ){ret->length = 0;ret->header.next = NULL;ret->header.pre = NULL;ret->slider = NULL;}return ret;
}void DLinkList_Destroy(DLinkList* list)//定义销毁表函数
{free(list);
}void DLinkList_Clear(DLinkList* list) //定义清空重设表函数
{TDLinkList* sList = (TDLinkList*)list;if( sList != NULL ){sList->length = 0;sList->header.next = NULL;sList->header.pre = NULL;sList->slider = NULL;}
}int DLinkList_Length(DLinkList* list)//定义获取表当前长度函数
{TDLinkList* sList = (TDLinkList*)list;int ret = -1;if( sList != NULL ){ret = sList->length;}return ret;
}int DLinkList_Insert(DLinkList* list, DLinkListNode* node, int pos) //定义插入节点函数
{ TDLinkList* sList = (TDLinkList*)list;int ret = (sList != NULL) && (pos >= 0) && (node != NULL);//判断表与节点是否为空与pos是否正常int i = 0;if( ret ){DLinkListNode* current = (DLinkListNode*)sList;//指向header头节点DLinkListNode* next = NULL;//找到插入节点的前一个节点//current->next == NULL 表示是第一个节点for(i=0; (i<pos) && (current->next != NULL); i++){current = current->next;}next = current->next;//取得插入的位置本来的节点current->next = node;//将插入位置的上一个节点的next指向新插入节点node->next = next;//将本来该位置的节点赋给新插入节点的nextif( next != NULL )//如果本来该位置有节点{next->pre = node;//将本来该位置的节点的前节点指向新插入节点}node->pre = current;//将新插入节点的前节点指向前一个节点if( sList->length == 0 )//如果是第一个插入的节点{node->pre = NULL;//将第一个节点的前节点设空//注意:插入第一个节点后,再插入的节点如果是第一个位置slider不会更新还是第一次插入的第一个节点sList->slider = node;//给slider赋第一个节点}sList->length++;//长度增加}return ret;
}DLinkListNode* DLinkList_Get(DLinkList* list, int pos) //定义获取节点函数
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;int i = 0;if( (sList != NULL) && (0 <= pos) && (pos < sList->length) )//判断表是否为空与pos是否在范围内{DLinkListNode* current = (DLinkListNode*)sList;//指向header头节点for(i=0; i<pos; i++)//找得获取节点的前一个节点{current = current->next;}ret = current->next;//取得获取节点}return ret;
}DLinkListNode* DLinkList_Delete(DLinkList* list, int pos) //定义删除节点函数(根据下标删除)
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;int i = 0;if( (sList != NULL) && (0 <= pos) && (pos < sList->length) )//判断表是否为空与pos是否在范围内{DLinkListNode* current = (DLinkListNode*)sList;DLinkListNode* next = NULL;for(i=0; i<pos; i++)//找得删除节点的前一个节点{current = current->next;}ret = current->next;//取得要删除的节点next = ret->next;//取得要删除节点的下一个节点current->next = next;//将要删除节点的上一个节点的next指向要删除节点的下一个节点if( next != NULL )//如果next!=NULL 表示删除 节点不是最后一个节点{next->pre = current;//将其的pre指向要删除节点的上一个节点if( current == (DLinkListNode*)sList )//如果删除的节点的前一个节点是header头节点 表示删除了第一个节点{next->pre = NULL;//将删除节点的下一个节点pre指向NULL}}if( sList->slider == ret )//如果删除的节点是slider的指向{sList->slider = next;//将slider指向它的下一个节点}sList->length--;}return ret;
}DLinkListNode* DLinkList_DeleteNode(DLinkList* list, DLinkListNode* node)//定义删除节点函数(根据节点)
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;int i = 0;if( sList != NULL )//判断表是否为空{DLinkListNode* current = (DLinkListNode*)sList;//取得头节点for(i=0; i<sList->length; i++)//找到要删除节点{if( current->next == node ){ret = current->next;break;//找到后跳出查找}current = current->next;}if( ret != NULL )//如果有该节点{DLinkList_Delete(sList, i);//使用对应下标删除节点}}return ret;
}DLinkListNode* DLinkList_Reset(DLinkList* list)//定义重置slider指向函数
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;if( sList != NULL ){sList->slider = sList->header.next;//将第一个节点赋给sliderret = sList->slider;}return ret;//返回slider
}DLinkListNode* DLinkList_Current(DLinkList* list)//定义获取slider函数
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;if( sList != NULL ){ret = sList->slider;}return ret;//返回slider
}DLinkListNode* DLinkList_Next(DLinkList* list)//定义slider下移函数
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;if( (sList != NULL) && (sList->slider != NULL) ){ret = sList->slider;sList->slider = ret->next;}return ret;//返回slider
}DLinkListNode* DLinkList_Pre(DLinkList* list)//定义slider上移函数
{TDLinkList* sList = (TDLinkList*)list;DLinkListNode* ret = NULL;if( (sList != NULL) && (sList->slider != NULL) ){ret = sList->slider;sList->slider = ret->pre;}return ret;//返回slider
}
main.c
#include <stdio.h>
#include <stdlib.h>
#include "DLinkList.h"struct Value
{DLinkListNode header;//必须在结构体中第一个元素int v;
};int main(int argc, char *argv[])
{int i = 0;DLinkList* list = DLinkList_Create();struct Value* pv = NULL;struct Value v1;struct Value v2;struct Value v3;struct Value v4;struct Value v5;v1.v = 1;v2.v = 2;v3.v = 3;v4.v = 4;v5.v = 5;DLinkList_Insert(list, (DLinkListNode*)&v1, DLinkList_Length(list));DLinkList_Insert(list, (DLinkListNode*)&v2, DLinkList_Length(list));DLinkList_Insert(list, (DLinkListNode*)&v3, DLinkList_Length(list));DLinkList_Insert(list, (DLinkListNode*)&v4, DLinkList_Length(list));DLinkList_Insert(list, (DLinkListNode*)&v5, DLinkList_Length(list));for(i=0; i<DLinkList_Length(list); i++){pv = (struct Value*)DLinkList_Get(list, i);printf("%d\n", pv->v);}printf("\n");DLinkList_Delete(list, DLinkList_Length(list)-1);DLinkList_Delete(list, 0);for(i=0; i<DLinkList_Length(list); i++){pv = (struct Value*)DLinkList_Next(list);printf("%d\n", pv->v);}printf("\n");DLinkList_Reset(list);DLinkList_Next(list);pv = (struct Value*)DLinkList_Current(list);printf("%d\n", pv->v);DLinkList_DeleteNode(list, (DLinkListNode*)pv);pv = (struct Value*)DLinkList_Current(list);printf("%d\n", pv->v);DLinkList_Pre(list);pv = (struct Value*)DLinkList_Current(list);printf("%d\n", pv->v);printf("Length: %d\n", DLinkList_Length(list));DLinkList_Destroy(list);getchar();return 0;
}
分析:
汇编: