2

我一直无法让这部分代码工作。我正在尝试复制要复制的字符数组,以便计算有多少令牌可以动态分配并保存以检查环境变量。但是,当它尝试对原始字符串进行 strncpy 时,我会不断出现段错误。

    void echo(char *str1)
    {
      char *token, *temp;
      char *saveptr1;
      int j, i, k, counter;
      char *copy;

      strncpy(copy, str1, 80);

      const char *delim = " ";
      i = strlen(copy);

      for(j = 0; j < i; j++, copy = NULL)
      {
         token = strtok_r(copy, delim, &saveptr1);
         counter++;
         if(token == NULL)
         {
           counter--;
           break;
         }
      }

      // initialize token array for echo
      char *tokAr[counter];
      for(j = 0; j < counter; j++)
        tokAr[j] = malloc(80*sizeof(char));

      for(j = 0, k = 0; j < i; j++, str1 = NULL)
      {
         tokAr[k] = strtok_r(str1, delim, &saveptr1);
         if( tokAr[k] != NULL)
         {
            if(strchr(tokAr[k], 36) != NULL)
            {
              temp = enviro(tokAr[k]);
              printf("%s ", temp);
            }
         else
           printf("%s ", tokAr[k]);
         }
         else
           break;
      }

      for(k = 0; k < counter; k++)
        free(tokAr[k]);
    }

    char* enviro(char *ret)
    {
      char *copy, *expand, *saveptr;
      const char *delim = "$";
      strcpy(copy, ret);
      expand = strtok_r(copy, delim, &saveptr);

      return getenv(expand);
    }

我知道这与我如何复制传入的 str1 字符数组有关,但我无法从 gdb 中弄清楚。任何帮助是极大的赞赏

4

3 回答 3

9

您还没有为copy.

char *copy;
strncpy(copy, str1, 80);

试试看malloc,或者strdup如果您不需要完整的 81 个字符。

copy = malloc(81);
strncpy(copy, str1, 80);

/* Or strdup. */
copy = strdup(str1);
于 2011-09-26T07:04:34.063 回答
2

copy不包含有效的分配地址。malloc请在使用前分配足够的内存copy。还记得copy在完成使用它后释放它以阻止大型程序中的内存泄漏。

于 2011-09-26T07:19:25.033 回答
0

我认为在函数 echo 中,您尚未初始化变量 counter 并尝试对其进行递增和递减。尝试这样做。

于 2011-09-26T08:52:48.170 回答