strcat小bug引起的大问题

在调试STM32时,单步打断点运行时,没有问题,但是全速运行时,偶尔会跳过错误,偶尔也会跳转hardfault;

问题实在难找。。。

最后定位在发送数据的缓存上, 发现发送缓存部分除了应该有的数据之外, 还有好多不 为0的值;

也就是说,在栈上申请的内存,没有经过初始化,就使用strcat来追加字符串了;

详细查了一下strcat的用法,发现strcat需要先找到dest的结尾,才能够继续追加;

如果申请的内存没有初始化, 可能就会导致追加的字符串的位置不正确;从而可能导致了内存溢出(覆盖);

所以 程序就崩了。。。 

贴上glibc的strcat的源码

char *

strcat (dest, src)

    char *dest;

    const char *src;

{

 char *s1 = dest;

 const char *s2 = src;

 reg_char c;

 /* Find the end of the string.  */

 do

 c = *s1++;

 while (c != '\0');

  /* Make S1 point before the next character, so we can increment

     it while memory is read (wins on pipelined cpus).  */
  s1 -= 2; 

  do

    {

      c = *s2++;

      *++s1 = c;

    }

  while (c != '\0');

  return dest;

}

永不止步步 发表于04-01 10:08 浏览65535次
分享到:

已有0条评论

暂时还没有回复哟,快来抢沙发吧

添加一条新评论

只有登录用户才能评论,请先登录注册哦!

话题作者

永不止步步
金币:67410个|学分:345327个
立即注册
畅学电子网,带你进入电子开发学习世界
专业电子工程技术学习交流社区,加入畅学一起充电加油吧!

x

畅学电子网订阅号