嵌入式自学第二十一天(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

相关推荐
机器学习之心1 小时前
多目标鲸鱼优化算法(NSWOA),含46种测试函数和9个评价指标,MATLAB实现
算法·matlab·多目标鲸鱼优化算法·46种测试函数·9个评价指标
西阳未落2 小时前
C++基础(21)——内存管理
开发语言·c++·面试
我的xiaodoujiao2 小时前
Windows系统Web UI自动化测试学习系列2--环境搭建--Python-PyCharm-Selenium
开发语言·python·测试工具
max5006002 小时前
基于Meta Llama的二语习得学习者行为预测计算模型
人工智能·算法·机器学习·分类·数据挖掘·llama
callJJ2 小时前
从 0 开始理解 Spring 的核心思想 —— IoC 和 DI(2)
java·开发语言·后端·spring·ioc·di
wangjialelele2 小时前
Linux中的线程
java·linux·jvm·c++
谷咕咕2 小时前
windows下python3,LLaMA-Factory部署以及微调大模型,ollama运行对话,开放api,java,springboot项目调用
java·windows·语言模型·llama
没有bug.的程序员3 小时前
MVCC(多版本并发控制):InnoDB 高并发的核心技术
java·大数据·数据库·mysql·mvcc
在下村刘湘3 小时前
maven pom文件中<dependencyManagement><dependencies><dependency> 三者的区别
java·maven
王哥儿聊AI3 小时前
Lynx:新一代个性化视频生成模型,单图即可生成视频,重新定义身份一致性与视觉质量
人工智能·算法·安全·机器学习·音视频·软件工程