-1

希望有人可以提供帮助。我让这个程序完美运行,将几行代码从一个函数移动到另一个函数,结果一切都崩溃了。

我在下面的函数顶部包含了一个片段,直到段错误。它高兴地输出“我们到了吗?” 但不是下一个声明,我花了很多时间试图弄清楚这一点,以至于我不记得我必须开始的工作构建

它(至少下面的部分)应该将整个文本文件复制到一个字符串

故事的寓意:工作代码比“正确”代码更好,在尝试调整之前总是复制工作代码。

void validateFile(FILE* file, char** menuStore, char** submenuStore)
{

    char* temp = NULL;
    size_t size;
    boolean flag = true;
    char first;

    /*Loop Counter*/
    int i;

    fseek(file, 0, SEEK_END);
    size = ftell(file) * sizeof(char);
    fseek(file, 0, SEEK_SET);

    if ((temp = malloc(size)) == NULL)
    {
        printf("\nUnable to allocate Memory, Program exiting");
        exit(EXIT_FAILURE);
    } else
    {
        for (i = 0; i < (size / sizeof(char)); i++)
        {
            temp[i] = fgetc(file);
        }

        printf("\n did we get here?");
        printf("\nFile loaded, validating...");
4

1 回答 1

-1

从文件中读取时,您不应使用这样的循环-

for (i = 0; i < (size / sizeof(char)); i++)
{
    temp[i] = fgetc(file);
}

EOF您应该在读取文件时检查条件 -

i=0;
while((temp[i]=fgetc(file))!=EOF)
     i++;

并将字符串结束为\0. 这是更好的方法。

temp[i]='\0';
于 2014-08-13T12:02:59.830 回答