嵌入式自学第二十一天(5.14)

gdb逻辑调试器:

gcc 调试,发行版

gcc -g 调试版本,体积大,有源码。

一般调试:gdb a.out

b n.c:行数 :设置断点,运行到这个位置,程序暂停。(可以直接加行数)

r运行

n执行下一命令,若有函数,下一命令就是函数执行完的下一命令,s跟进自定义函数。

使用p命令,查看指针或变量数据。

q退出。

Start Main函数开始

n一步步执行

where找出段错误位置

Display 变量:每次执行下一步并查看变量值。

list列出函数

Valgrand 内存泄漏检测

/**回车,标准头文件备注格式。函数功能,参数介绍,返回值qq

今天还学习了剩下几个链表操作,尾部插入元素、指定位置插入元素、元素替换、和链表清空。代码如下:

int InsertTailLinkList(LinkList* ll, DATATYPE* data)

{

if (IsEmptyLinkList(ll))

{

return InsertHeadLinkList(ll, data);

}

else

{

LinkNode* newnode = malloc(sizeof(LinkNode));

if (NULL == newnode)

{

fprintf(stderr, "InsertTailLinkList malloc");

return 1;

}

memcpy(&newnode->data,data,sizeof(DATATYPE));

newnode->next = NULL;

LinkNode* tmp = ll->head;

while(tmp->next)

{

tmp = tmp->next; //tmp++;

}

tmp->next = newnode;

ll->clen++;

}

return 0;

}

int InsertPosLinkList(LinkList*ll,DATATYPE*data,int pos)

{

int len = GetSizeLinkList(ll);

if(pos<0 || pos>len)

{

return 1;

}

if(0==pos) //head

{

return InsertHeadLinkList(ll,data);

}

else if(pos == len) //tail

{

return InsertTailLinkList(ll, data);

}

else

{

LinkNode* newnode = malloc(sizeof(LinkNode));

if (NULL == newnode)

{

fprintf(stderr, "InsertPosLinkList malloc");

return 1;

}

memcpy(&newnode->data,data,sizeof(DATATYPE));

newnode->next = NULL;

int i = 0 ;

LinkNode* tmp = ll->head;

for(i = 0 ;i<pos-1;++i)

{

tmp= tmp->next;

}

newnode->next = tmp->next;

tmp->next = newnode;

}

ll->clen++;

return 0;

}

int ModifyLinkList(LinkList*ll,char*name,DATATYPE*data)

{

DATATYPE * tmp = FindLinkList(ll, name);

if(NULL == tmp)

{

return 1;

}

memcpy(tmp,data,sizeof(DATATYPE));

return 0;

}

int DestroyLinkList(LinkList**ll)

{

while(1)

{

LinkNode* tmp = (*ll)->head;

if(NULL == tmp)

{

break;

}

(*ll)->head = (*ll)->head->next;

free(tmp);

}

free(*ll);

*ll = NULL;

return 0;

}

顺序表和链表 优缺点

存储方式:

顺序表是一段连续的存储单元

链表是逻辑结构连续物理结构(在内存中的表现形式)不连续

时间性能,

查找 顺序表O(1)

链表 O(n)

插入和删除

顺序表 O(n)

链表 O(1)

空间性能

顺序表 需要预先分配空间,大小固定

链表, 不需要预先分配,大小可变,动态分配

循环链表

简单的来说,就是将原来单链表中最有一个元素的next指针指向第一个元素或头结点,链表就成了一个环,头尾相连,就成了循环链表。circultlar linker list

相关推荐
纽扣6678 分钟前
【算法进阶之路】链表进阶:删除、合并、回文与排序全解析
数据结构·算法·链表
9523622 分钟前
SpringBoot统一功能处理
java·spring boot·后端
有一个好名字24 分钟前
工具即双手 —— 从 Bash 到 Tool Dispatch Map
开发语言·chrome·bash
Lyyaoo.25 分钟前
优惠券秒杀业务分析
java·开发语言
消失的旧时光-194325 分钟前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法
勿忘初心122129 分钟前
Java 国密 SM4 加密工具类实战(Hutool + BouncyCastle)|企业级数据加密 + 兼容 JDK8
java·数据安全·数据加密·后端开发·企业级开发·国密 sm4
庞轩px32 分钟前
第8篇:原子类与CAS底层原理——无锁并发的实现
java·cas·乐观锁·aba·无锁编程·自旋
智者知已应修善业36 分钟前
【51单片机不用数组动态数码管显示字符和LED流水灯】2023-10-3
c++·经验分享·笔记·算法·51单片机
rleS IONS43 分钟前
SpringBoot中自定义Starter
java·spring boot·后端
DevilSeagull1 小时前
MySQL(2) 客户端工具和建库
开发语言·数据库·后端·mysql·服务