博客
关于我
【链表问题】建立链表遇到的问题(链表突然消失,链表突然全部为空)_liangchaoxi的IT博客_新浪博客...
阅读量:478 次
发布时间:2019-03-06

本文共 759 字,大约阅读时间需要 2 分钟。

 在单片机程序内建立链表时候,无法为第三个节点开辟空间,现象是,建立链表的时候,第一个和第二个节点均能正确加入,将第三个节点加入的时候,整个链表内的为空。

 原因是:

 单片机使用Mallco时候要考虑指定区域,指定的区域一定要足够大。

 我们调试的时候,就是在IAR中增加堆栈的空间。 

 

在IAR中调试程序,遇到了这样的问题,那就是,程序运行的过程当中,链表的内容突然为空,读取链表的内容失败。分析了一下原因是,一开始我们是只发现添加失败,添加前面的1、2个单元是成功的,到了第三个就失败了,查看了分配空间的程序malloc,malloc分配一个连续的空间,如果分配失败,返回的就是一个空地址,而我们的链表头刚好等于返回值Token_Head=inset(Token_Head,New_point);,所以链表头“不见了”,自然链表就消失了。

 

 

删除节点后应该,释放空间,要不然,再需要重复插入删除的程序中,插入的空间不会被重新利用,而新插入的又要新的空间,如此反复,再大的空间也不够用。下面这个程序放在循环中,循环到一定的次数,就会看到,链表突然“全部变为空”。

 

void Test_List(void)//建立固定链表
{
  for(i=0;i<60;i++)
  {
    strcpy(Mark_Del_Node,Token_Head->MacID);
    Token_Head=del( Token_Head,"0005");
    struct MacID_Struct *New_point;
    New_point=(struct MacID_Struct*)malloc(LEN);
    strcpy(New_point->MacID,"0005");
    Token_Head=inset(Token_Head,New_point);
  }
}

转载地址:http://kkidz.baihongyu.com/

你可能感兴趣的文章
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>