目录:

  • 代码:
  • 分析:
  • 汇编:

代码:

CircleList.h

#ifndef _CIRCLELIST_H_
#define _CIRCLELIST_H_typedef void CircleList;typedef struct _tag_CircleListNode CircleListNode;struct _tag_CircleListNode{CircleListNode *next;};CircleList * CircleList_Create();void CircleList_Destroy(CircleList* list);void CircleList_Clear(CircleList* list);int  CircleList_Length(CircleList* list);int CircleList_Insert(CircleList* list, CircleListNode* node, int pos);CircleListNode* CircleList_Get(CircleList* list, int pos);CircleListNode* CircleList_Delete(CircleList* list, int pos);CircleListNode* CircleList_DeleteNode(CircleList* list, CircleListNode* node);CircleListNode* CircleList_Reset(CircleList* list);CircleListNode* CircleList_Current(CircleList* list);CircleListNode* CircleList_Next(CircleList*list);#endif

CircleList.c

#include<stdio.h>
#include<malloc.h>
#include"CircleList.h"typedef struct _tag_CircleList{CircleListNode header;//头节点CircleListNode* slider;int length;
}TCircleList;CircleList * CircleList_Create(){//定义创建表函数TCircleList * ret = (TCircleList*)malloc(sizeof(TCircleList));if (ret != NULL){ret->length = 0;ret->header.next = NULL;ret->slider = NULL;}return ret;
}void CircleList_Destroy(CircleList * list){//定义销毁表函数free(list);
}void CircleList_Clear(CircleList* list){//定义重设表属性函数TCircleList* sList = (TCircleList*)list;if (sList != NULL){sList->length = 0;sList->header.next = NULL;sList->slider = NULL;}
}int  CircleList_Length(CircleList * list){//定义获取表当前长度函数TCircleList *sList = (TCircleList*)list;int ret = -1;if (sList != NULL){ret = sList->length;}return ret;
}int CircleList_Insert(CircleList * list, CircleListNode* node, int pos){//定义插入节点函数TCircleList *sList = (TCircleList*)list;int ret = (sList != NULL) && (pos >= 0) && (node != NULL);//判断表与节点是否为空和pos是否正常int i = 0;if (ret){CircleListNode* current = (CircleListNode*)sList; //取得表的header元素地址//取得插入节点位置的前一个节点//current->next == NULL 表示是第一个插入的节点//注意:这没有对pos判断,pos大于length时会循环for (i = 0; (i < pos) && (current->next != NULL); i++){current = current->next;}//注意:插入第一个节点后,再插入的节点如果不是第一个位置才能正常循环//可以在链表结构加一个尾节点指针变量保持指向尾节点,每次尾节点更改后再更新node->next = current->next;//将原本在pos位置的节点赋给新插入节点的nextcurrent->next = node;//将插入节点赋给插入节点位置的前一个节点的nextif (sList->length == 0){ //如果是第一个插入的节点//注意:插入第一个节点后,再插入的节点如果是第一个位置slider不会更新还是第一次插入的第一个节点sList->slider = node;//将第一个插入节点赋给slider      node->next = node;//将第一个插入节点的next指向自身(实现循环) }sList->length++;//长度增加}return ret;
}CircleListNode* CircleList_Get(CircleList* list, int pos){//定义获取节点函数TCircleList * sList = (TCircleList*)list;CircleListNode* ret = NULL;int i = 0;if ((sList != NULL) && (pos >= 0)){CircleListNode* current = (CircleListNode*)sList;for (i = 0; i < pos; i++){ //取得前一个节点//注意:这没有对pos判断,pos大于length时会循环current = current->next;}ret = current->next; //取得要获取的节点}return ret;
}CircleListNode* CircleList_Delete(CircleList* list, int pos){//定义根据下标删除节点函数TCircleList *sList = (TCircleList*)list;CircleListNode * ret = NULL;int i = 0;if ((sList != NULL) && (pos >= 0)){//判断表是否为空与pos是否正常CircleListNode* current = (CircleListNode*)sList;//指向头节点CircleListNode* first = sList->header.next;//指向第一个节点CircleListNode* last = (CircleListNode*)CircleList_Get(sList, sList->length-1);//指向最后一个节点for (i = 0; i < pos; i++){//找到要删除位置的前一个位置current = current->next;}ret = current->next;//指向要删除节点current->next = ret->next;//将要删除节点的next赋给上一节点的nextsList->length--;//长度减少if (first == ret){ //如果是第一个节点//这一步好像多余,上面current就是headersList->header.next = ret->next;//将头节点指向第一个节点的下一个last->next = ret->next;//将最后一个节点的next指向第一个节点的下一个实现循环}if (sList->slider == ret){//如果删除的节点是第一个插入的节点sList->slider = ret->next;//删除节点的下个节点赋给slider}if (sList->length == 0){//如果长度等于0,表示链表没有数据了sList->header.next = NULL; //重置第一个节点的指向sList->slider = NULL;//重置slider}}return ret;//返回删除节点
}CircleListNode* CircleList_DeleteNode(CircleList * list, CircleListNode * node){//定义根据节点删除节点函数TCircleList* sList = (TCircleList*)list;CircleListNode *ret =NULL;int i = 0;if (sList != NULL){//判断表是否为空CircleListNode* current = (CircleListNode*)sList;//指向头节点for (i = 0; i < sList->length; i++){if (current->next == node){//找到删除节点的上一个节点ret = current->next;//指向删除节点break; //找到后跳出循环查找}current = current->next;}if (ret != NULL){//如果有该节点CircleList_Delete(sList, i);//将下标转去执行删除}}return ret;//返回删除节点
}CircleListNode* CircleList_Reset(CircleList* list){//定义重置slider指向的函数TCircleList* sList = (TCircleList*)list;CircleListNode* ret = NULL;if (sList != NULL){//如果表不为空sList->slider = sList->header.next;//将第一个节点赋给sliderret = sList->slider;}return ret;//返回slider}CircleListNode* CircleList_Current(CircleList* list){//定义slider当前指向节点函数TCircleList* sList = (TCircleList*)list;CircleListNode* ret = NULL;if (sList != NULL){ret = sList->slider;}return ret;//返回slider
}CircleListNode* CircleList_Next(CircleList *list){//定义slider下移一个节点函数TCircleList* sList = (TCircleList*)list;CircleListNode* ret = NULL;if ((sList != NULL) && (sList->slider != NULL)){//判断表不为空与slider不为空ret = sList->slider;sList->slider = ret->next;//将slider的next赋给slider}return ret;//返回slider;
}

main.c

#include<stdio.h>
#include<stdlib.h>
#include"CircleList.h"struct Value{CircleListNode header;//必须放在第一个元素int v;
};
int main(int argc, char *argv[]){int i = 0;CircleList* list = CircleList_Create();struct Value v1;struct Value v2;struct Value v3;struct Value v4;struct Value v5;struct Value v6;struct Value v7;struct Value v8;v1.v = 1;v2.v = 2;v3.v = 3;v4.v = 4;v5.v = 5;v6.v = 6;v7.v = 7;v8.v = 8;CircleList_Insert(list, (CircleListNode*)&v1, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v2, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v3, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v4, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v5, 5);CircleList_Delete(list, 0);for (i = 0; i < 2 * CircleList_Length(list); i++){struct Value* pv = (struct Value*)CircleList_Get(list, i);printf("%d\n", pv->v);}printf("\n");while (CircleList_Length(list)>0){struct Value*pv = (struct Value*)CircleList_Delete(list, 0);printf("%d\n", pv->v);}printf("\n");CircleList_Insert(list, (CircleListNode*)&v1, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v2, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v3, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v4, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v5, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v6, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v7, CircleList_Length(list));CircleList_Insert(list, (CircleListNode*)&v8, CircleList_Length(list));for (i = 0; i < CircleList_Length(list); i++){struct Value* pv = (struct Value*)CircleList_Next(list);printf("%d\n", pv->v);}getchar();return 1;
}

分析:










汇编:
















循环链表(代码、分析、汇编)相关推荐

  1. 通过汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的

    实验目的: 通过反汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的 实验过程: 通过vi程序进行编程: int g(int x) { return x + 3; } int f(int x) ...

  2. c理c利用计算机怎么弹,通过汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的...

    通过汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的 计算机的工作方式: 现代计算机的基本体系结构都是采用冯诺依曼结构,冯诺依曼的设计思想最重要之处是"存储程序"的这个概念 ...

  3. Linux内核汇编代码分析

    Linux内核汇编代码分析 1.vmlinux.lds.S文件分析 1.2 vmlinux.lds.S文件总体框架 1.3 代码段 1.4 只读数据段 1.5 init段 1.6 数据段 1.7 未初 ...

  4. 【汇编语言与计算机系统结构笔记05】汇编的系统结构,从C代码生产汇编代码,一个具体的、经典的数据传送指令(mov)实例与分析

    本次笔记内容: 06.寻址模式与数据传输指令等 文章目录 汇编程序员眼中的系统结构 如何从C代码生产汇编代码 如何装gcc? 汇编语言数据格式 第一条汇编指令实例 数据传送指令(mov) 语法与操作数 ...

  5. Device Tree(三):代码分析

    2019独角兽企业重金招聘Python工程师标准>>> 一.前言 Device Tree总共有三篇,分别是: 1.为何要引入Device Tree,这个机制是用来解决什么问题的?(请 ...

  6. ARM裸机篇---启动代码分析

    ARM裸机篇---启动代码分析 先搞清楚启动代码和Bootloader的区别,启动代码是指CPU复位后到进入C语言的main函数之前需要执行的那段汇编代码. 下面的代码先暂且这样吧,没啥注释的,时间关 ...

  7. 模块加载过程代码分析1

    一.概述 模块是作为ELF对象文件存放在文件系统中的,并通过执行insmod程序链接到内核中.对于每个模块,系统都要分配一个包含以下数据结构的内存区. 一个module对象,表示模块名的一个以null ...

  8. kernel 3.10代码分析--KVM相关--虚拟机创建\VCPU创建\虚拟机运行

    分三部分:一是KVM虚拟机创建.二是VCPU创建.三是KVM虚拟机运行 第一部分: 1.基本原理 如之前分析,kvm虚拟机通过对/dev/kvm字符设备的ioctl的System指令KVM_CREAT ...

  9. s3c6410 uboot代码分析《一》

    来源:http://hi.baidu.com/__eabi/blog/item/be67533797bc73f014cecb49.html 以下用以记录uboot代码的分析过程,目标是s3c6410, ...

  10. u-boot分析之两阶段代码分析(三)

    目录 u-boot(三)启动文件 1,概述 2,uboot第一阶段代码分析: 汇编 2,uboot第二阶段代码分析 C:_start_armboot C:main_loop u-boot(三)启动文件 ...

最新文章

  1. pytorch CrossEntropyLoss用法
  2. 用于文本识别的合成数据生成器
  3. SiftingAppender:将不同的线程记录到不同的日志文件中
  4. 工厂模式 + 反射 ?= 灵活多变的数据库
  5. C++(4)--初识变量、数据类型
  6. python中try怎么用_python下try
  7. RocketMQ 消息队列单机部署及使用
  8. Matlab R2016a安装教程
  9. 常用的laplace变换公式表
  10. 工频变压器和高频变压器
  11. 杨义先:大数据的道性
  12. oracle count 1 count 区别,Count(1)和count(*)区别
  13. Elsevier论文模板没有author biography的解决办法
  14. C++ builder热键处理方式(HotKey)
  15. 字节跳动+阿里+华为+小米等10家大厂面试真题,已开源
  16. macOS 安卓模拟器 Genymotion 安装
  17. capsule系列之Dynamic Routing Between Capsules
  18. 《工程测量学》考试复习总结
  19. Java实现FTP下载文件到客户端(浏览器)
  20. ios微信浏览器App下载链接怎样跳转到苹果App Store

热门文章

  1. vue 外部方法调用内部_vue函数内部调用外部函数,报错外部函数不是函数
  2. SVN版本控制系统学习(中文配置)
  3. 2.2 .this的绑定规则
  4. Ocrad.js – JS 实现 OCR 光学字符识别
  5. 子组件上下结构布局自适应父组件宽度高度
  6. java中值传递和引用传递
  7. 关于数据库表的“记录”与“字段”
  8. matlab生成HEX文件-任意信号 大于64K长度
  9. [蓝桥杯历届试题] 欧拉与鸡蛋
  10. python爬虫requests实战_Python爬虫之requests库网络爬取简单实战