为什么我的动态分配内存中的值看起来像是被覆盖了

发布于 2025-01-09 16:24:57 字数 2636 浏览 0 评论 0原文

我正在处理一项任务,该任务应该将字符串解析为单独的标记,而不使用 c 字符串库,同时动态分配任何必要的内存。我以为我一切正常,但现在看起来每次我写入新值时每个值都会被覆盖。

这是我的代码。抱歉,这是一团糟,我一直很匆忙,不情愿地一直在使用我不完全理解的功能。这个问题可能很愚蠢,但我没时间了,而且很明显我自己可能无法解决它。

int makearg(char s[], char **args[]);

int main() {    char **tokenArray;    char strInput[MAXSTRING];    int tokenResult;    int i = 0;

   printf("Input String to be Parsed: ");    scanf("%[^\n]%*c", strInput);

   tokenResult = makearg(strInput, &tokenArray);

   printf("argc: %d\n", tokenResult);    for (i = 0; i < tokenResult; i++)    {
      printf("arg(%d): %s\n", i, tokenArray[i]);    } }

int makearg(char s[], char **args[]) {    int numTokens = 0;    int lastSpace = 0;    int i;    int fakeI;    char token[MAXSTRING];       int subFromPos = 0;    int firstToken = 1;

   *args = NULL;    while ((s[i] != '\n') && (s[i] != '\0') && (s[i] != '\r'))    {
      fakeI = i;

      if ((s[i + 1] == '\n') || (s[i + 1] == '\0'))
      {
         fakeI = i + 1;
      }

      token[i - lastSpace - subFromPos] = s[i];

      if ((s[fakeI] == ' ') || (s[fakeI] == '\n') || (s[fakeI] == '\0') || (s[fakeI] == '\r'))
      {
         if (firstToken == 1)
         {
            token[fakeI - lastSpace] = '\0';
            firstToken = 0;
         } else if (firstToken == 0){
            token[i - lastSpace] = '\0';
            printf("Saved Token 1: %s\n", *args[numTokens - 1]); //test to see if the token got written properly
            if (numTokens > 1){
               printf("Prior Saved Token: %s\n", *args[numTokens - 2]); //test to see if the tokens are overwritten
            }
            if (numTokens > 2){
               printf("Prior Saved Token 2: %s\n", *args[numTokens - 3]); //test to see if the tokens are overwritten
            }
         }
         *args = realloc(*args, (numTokens + 1));
         args[numTokens] = NULL;
         args[numTokens] = realloc(args[numTokens], (fakeI - lastSpace + 1));
         *args[numTokens] = token;
         printf("Saved Token: %s\n", *args[numTokens]); //test to see if the token got written properly
         numTokens++;
         lastSpace = fakeI;
         subFromPos = 1;
      }
      i++;    }    numTokens++;    return numTokens; }

无论出于何种原因,Saved Token、Saved Token 1、Prior Saved Token 和 Prior Saved Token 2 每次运行时都会打印相同的值(我的意思是,如果其中一个打印单词“hello”,它们都会打印单词 hello这似乎告诉我以前的数据正在被覆盖。

此外,主函数中的 for 循环应该遍历并打印数组中的每个值,但它只打印以下内容(在这种情况下我是)。测试用字符串“你好,我真正的朋友”:

arg(0):朋友

arg(1): (空)

arg(2): (空)

我在这里做错了什么?我确信我忽略了一些愚蠢的东西,但我就是找不到它。是不是我数据写错了?它实际上没有被覆盖而只是打印错误吗?此时,任何建议都将不胜感激。

I'm working on an assignment that is supposed to parse a string into separate tokens without the use of the c string library and while dynamically allocating any necessary memory. I thought I had everything working correctly, except now it looks like every value is being overwritten every time I write a new value.

Here's my code. Sorry it's a mess, I've been in a hurry and reluctantly have been working with functions I don't fully understand. The problem is probably something dumb, but I'm out of time and it's clear I probably wont be able to figure it out myself.

int makearg(char s[], char **args[]);

int main() {    char **tokenArray;    char strInput[MAXSTRING];    int tokenResult;    int i = 0;

   printf("Input String to be Parsed: ");    scanf("%[^\n]%*c", strInput);

   tokenResult = makearg(strInput, &tokenArray);

   printf("argc: %d\n", tokenResult);    for (i = 0; i < tokenResult; i++)    {
      printf("arg(%d): %s\n", i, tokenArray[i]);    } }

int makearg(char s[], char **args[]) {    int numTokens = 0;    int lastSpace = 0;    int i;    int fakeI;    char token[MAXSTRING];       int subFromPos = 0;    int firstToken = 1;

   *args = NULL;    while ((s[i] != '\n') && (s[i] != '\0') && (s[i] != '\r'))    {
      fakeI = i;

      if ((s[i + 1] == '\n') || (s[i + 1] == '\0'))
      {
         fakeI = i + 1;
      }

      token[i - lastSpace - subFromPos] = s[i];

      if ((s[fakeI] == ' ') || (s[fakeI] == '\n') || (s[fakeI] == '\0') || (s[fakeI] == '\r'))
      {
         if (firstToken == 1)
         {
            token[fakeI - lastSpace] = '\0';
            firstToken = 0;
         } else if (firstToken == 0){
            token[i - lastSpace] = '\0';
            printf("Saved Token 1: %s\n", *args[numTokens - 1]); //test to see if the token got written properly
            if (numTokens > 1){
               printf("Prior Saved Token: %s\n", *args[numTokens - 2]); //test to see if the tokens are overwritten
            }
            if (numTokens > 2){
               printf("Prior Saved Token 2: %s\n", *args[numTokens - 3]); //test to see if the tokens are overwritten
            }
         }
         *args = realloc(*args, (numTokens + 1));
         args[numTokens] = NULL;
         args[numTokens] = realloc(args[numTokens], (fakeI - lastSpace + 1));
         *args[numTokens] = token;
         printf("Saved Token: %s\n", *args[numTokens]); //test to see if the token got written properly
         numTokens++;
         lastSpace = fakeI;
         subFromPos = 1;
      }
      i++;    }    numTokens++;    return numTokens; }

For whatever reason Saved Token, Saved Token 1, Prior Saved Token, and Prior Saved Token 2 all print the same value every time they run (by which I mean if one of them prints the word "hello", they all print the word hello. That seems to tell me that the previous data is being overwritten.

Additionally, the for-loop in the main function is supposed to go through and print every value in the array, but instead it's only printing the following (in this scenario I was testing with the string "hello my one true friend":

arg(0): friend

arg(1): (null)

arg(2): (null)

What am I doing wrong here? I'm sure it's something dumb that I'm overlooking, but I just can't find it. Am I writing in the data incorrectly? Is it actually not being overwritten and just being printed incorrectly. At this point any advice at all would be greatly appreciated.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

家住魔仙堡 2025-01-16 16:24:57

好吧,我的开发环境

int i;  <<<<=====
int fakeI;
char token[255];
int subFromPos = 0;
int firstToken = 1;

*args = NULL;
while ((s[i] != '\n') && (s[i] != '\0') && (s[i] != '\r')) { <<<<<=

立即给出了

C4700   uninitialized local variable 'i' used

在所有赌注都结束后

Ok well my dev env picked up immediatly

int i;  <<<<=====
int fakeI;
char token[255];
int subFromPos = 0;
int firstToken = 1;

*args = NULL;
while ((s[i] != '\n') && (s[i] != '\0') && (s[i] != '\r')) { <<<<<=

gave

C4700   uninitialized local variable 'i' used

after that all bets are off

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文