glibc检测到双重免费或腐败

时间:2013-06-18 07:03:00

标签: c linux memory-management

我有以下功能,它从串行设备读取缓冲区,获取一些令牌并每10秒打印一次这些令牌。我希望这些结果将它们保存在我在桌面上创建的data.txt中。在第一个循环中我有结果,我也在txt文件中有它们但第二次出现此错误

***glibc detected***/home/pi/Desktop/programming/bin/Debug/programming: double free or corruption(top):0x00dbe178 ***

我知道这个问题与我分配的可用内存有关,但我不知道代码中的问题在哪里以及如何修复它。任何人都可以帮助我吗?

int learn_port2(int fd)
{
   int i;
   char buff[260];
   memset(buff, 0, sizeof(buff));
   char nodo[6] = "";
   char temp[6] = "";
   char hr[6] = "";
   char dw[6] = "";
   char vcc[6] = "";
   char* ptr;

   FILE *fp=fdopen(fd,"a+");
   FILE *ft = fopen("/home/pi/Desktop/data.txt","a+");
   time_t now;
   time(&now);

   while(fgets(buff, sizeof(buff), fp) != NULL)
   {
    fputs(buff,stdout);
    char *pos = strchr(buff,'N');
    if (pos)
    {

         ptr = strtok(buff, "Nodo_,=:V()");
         i = 0;
       while (ptr != NULL)
         {
          if (i == 0)
             strcat(nodo, ptr); 
          if (i == 2)
             strcat(temp, ptr); 
          if (i == 4)
             strcat(hr, ptr); 
          if (i == 6)
             strcat(dw, ptr); 
          if (i == 8)
             strcat(vcc, ptr);

          ptr = strtok(NULL, "Nodo_,=:V()");
          i++;
         }
       printf("Results: %s, %s, %s, %s, %s\n", nodo, temp, hr, dw, vcc);
       fprintf(ft,"%s,%s,%s,%s,%s\n", nodo, temp, hr, dw, vcc);

         fclose(ft);
      memset(nodo, 0, sizeof(nodo));
      memset(temp, 0, sizeof(temp));
      memset(hr, 0, sizeof(hr));
      memset(dw, 0, sizeof(dw));
      memset(vcc, 0, sizeof(vcc));
      printf("\n");
     }
  }

1 个答案:

答案 0 :(得分:0)

发布的代码无法编译(我猜失踪的}就在最后),但我可以指出一些问题:

  1. 您在阅读后不会终止buff,因此strchr和/或strtok可能会结束
  2. strcat进入固定大小的缓冲区,而不检查你复制的东西是否合适。你可以在这里轻松注销缓冲区的结尾
  3. fclose(ft)多次。您必须仅在循环外
  4. 执行此操作一次

    如果仍有错误,您应该修复所有这三项,并发布新的可编辑代码。