c - 适用于 gcc c11,但在 Clang 3.6 c11 上我得到 malloc() : memory corruption (fast): 0x0000000000fb8620

标签 c memory-management malloc clang c11

我有这个程序。当我使用 gcc egyptionFractions.c -o egypt -Wall -std=c11 在 gcc 上运行时,效果非常好!但是,我尝试在服务器上使用 llvm 运行它,但不断收到此错误:

* Error in `/home/codewarrior/solution': malloc(): memory corruption (fast): 0x0000000000fb8620 *

程序多次使用malloc和realloc,但找不到问题所在。我认为空字符串结尾可能会耗尽内存,但是当我增加分配大小时,我的答案就会偏离轨道......

该函数有两个数字,例如“3”和“4”。它以贪婪的方式分解分数,如“1/2 + 1/4”。您可以在底部看到示例输入和输出。

我真的很感谢你的帮助。同样,它在 gcc 上完美运行。 :) 而且我没有 llvm 编译器。我查看了其他一些涉及类似问题的线程,但没有找到可接受的解决方案。

#include <string.h>
#include <stdio.h>
#include <stdlib.h>

char* decompose(char* nrStr, char* drStr) {
  long long num = atof(nrStr);
  long long den = atof(drStr);
  double val = 1.0 * num / den;

  int curr_den = 2, curr_pos = 0;
  char * ans = malloc(1);
  ans[0] = 0;
  char denStr[50] = {0};

  if (val > 1)
  {
      sprintf(denStr, "%lld,", num/den);
      num -= (int)val * den;
      ans = realloc(ans, curr_pos += strlen(denStr) );
      strcat(ans, denStr);
  }
  printf("strlen:  %d\n", (int)strlen(denStr));
  while (num > 0)
  {
      if (1.0*num/den >= 1.0/curr_den)
      {
        num *= curr_den;
        if (num >= den)
        {
            num -= den;
            sprintf(denStr, "1/%d,", curr_den);
            ans = realloc(ans, curr_pos += strlen(denStr) );
            printf("strlen:  %d\n", (int)strlen(denStr));

            strcat(ans, denStr);
        }
        den *= curr_den;
      }
      curr_den++;
  }
  ans[curr_pos-1] = '\0';
  return ans;
}

void dotest(char* u, char* v, char* expr) {
    char* sact = decompose(u, v);
    if(strcmp(sact, expr) != 0)
        printf("Error. Expected %s but got %s\n", expr, sact);
    printf("%s\n%s\n\n", sact, expr);
    free(sact); sact = NULL;
}

int main () {

    dotest("3", "4", "1/2,1/4");
    dotest("12","4", "3");
    dotest("4","5", "1/2,1/4,1/20");
    dotest("66","100", "1/2,1/7,1/59,1/5163,1/53307975");
    dotest("22","23", "1/2,1/3,1/9,1/83,1/34362");
    //dotest("99","101", "1/2,1/3,1/7,1/250,1/132563");
    return 0;
}

最佳答案

解决方案是......我将这两个语句解耦后,然后在分配中加1..

    curr_pos += strlen(denStr);
    ans = realloc(ans, curr_pos+1 );

我正在这样做:

        ans = realloc(ans, curr_pos += strlen(denStr)+1 );

这把东西弄坏了!我在这里发帖,然后答案来得太快了。抱歉,如果我浪费了任何人的时间!

关于c - 适用于 gcc c11,但在 Clang 3.6 c11 上我得到 malloc() : memory corruption (fast): 0x0000000000fb8620,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43658933/

相关文章:

c - Delphi-to-C dll : Passing Arrays

android - Android 版本是否有最小堆大小?

c - C 中 ADT 列表迭代器的问题

iphone - 与分配工具一起使用时应用程序崩溃

c - 为什么在执行 memcpy 时检测到堆栈粉碎?

c - 如何知道C中单个程序分配的内存的完整大小?

c++ - NvAPI_GPU_GetAllDisplayIds 函数未按预期工作

c - stm8 读出保护 (ROP) 设置代码中的选项字节

C 数组第一个输入 "\0"

c - 为什么 scanf 和 printf 函数的语法中有一个指向常量的指针?