正确使用文件指针

时间:2016-02-10 01:01:24

标签: c pointers fopen fclose

我有一个关于文件指针的基本问题。在下面的代码中,我有一个while循环,后跟一个for循环。 for循环只会显示行数,除非我再次 fopen 文件 - 这是正常的吗?如果是这样我应该事先在while循环之后 fclose 吗?可能有一些"倒带"我不知道的功能,所以我的整个方法可能都是错的。我意识到while循环和for可以合并,但我的问题是关于 fopen fclose 并再次使用来自 fopen 的数据

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

#define MAXLEN 200

enum { MAXLINES = 200 };
char lpath[MAXLINES][BUFSIZ];

int main(int argc, char **argv) {

        char c;
        int l = 0, n = 0, i = 0, count = 0;
        char lines[MAXLINES][BUFSIZ];

        FILE *fp = fopen(argv[1], "r");

        if (fp == 0) {
                fprintf(stderr, "failed to open input.txt\n");
                exit(1);
        }

        while (l < MAXLINES && fgets(lines[l], sizeof(lines[0]), fp)) {
                lines[l][strlen(lines[l])-1] = '\0';
                puts(lines[l]);
                l++;
        }

        // fp = fopen(argv[1], "r"); // below won't output unless fopen again
        for (c = getc(fp); c != EOF; c = getc(fp)) {
            if (c == '\n') { 
                count++;

        }
        printf(">> line count: %i", count);

        fclose(fp);
}

还查看了:Pointer best practice

2 个答案:

答案 0 :(得分:5)

这是正常的,您需要rewind()该文件。问题是,当for循环启动文件已到达结束时,读取将失败,feof()将返回非零。

两个选项

rewind(fp);

或者

fseek(fp, 0L, SEEK_SET);

当您再次致电fopen()时,由于您覆盖指针而泄漏资源,现在您无法fclose()第一个fopen() ed文件。

答案 1 :(得分:0)

您可以使用rewind()作为@iharob建议,或者您可以关闭并重新打开该文件:

while (l < MAXLINES && fgets(lines[l], sizeof(lines[0]), fp)) {
            lines[l][strlen(lines[l])-1] = '\0';
            puts(lines[l]);
            l++;
}

fclose(fp);
fp = fopen(argv[1], "r"); // below won't output unless fopen again
for (c = getc(fp); c != EOF; c = getc(fp)) {
    if (c == '\n') { 
        count++;
    }
}