C中的getline()创建无限循环并跳过第一个单词?

贝维斯

我是C语言的初学者,我正在尝试创建一个简单的待办事项列表程序。我正在尝试在while循环中使用getline,正如我在另一个堆栈溢出答案中看到的那样,我以为我理解了,但这只是创建了一个无限循环。同样由于某种原因,它似乎也跳过了第一个单词。到目前为止,这是我的代码:

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

FILE *list;
int i = 0;
int item = 0;
char items[10];
char chars[1000];
char * line = NULL;
size_t len = 0;
ssize_t read;

int main() {
  list = fopen("/Users/bendavies/Documents/C/list.txt", "r");
  int letterCount = fscanf(list,"%s",chars);

  printf("Welcome to the to-do list. It can hold up to 10 items.\n");

  printf("%d\n", letterCount);

  if (letterCount == -1) {
    printf("The list currently has no items!\n");
  } else {
      while ((read = getline(&line, &len, list)) != 1) {
        item += 1;
        printf("%d. %s", item, line);
      }
    }
    fclose(list);

  return 0;
}

我目前使用以下list.txt获得的输出:

Eat food
Drink water
Breath air

是:

1.  food
2. Drink water
3. Breath air
4. 18446744073709551615
5. 18446744073709551615

等等等等。

先感谢您!:)

热心编码器

但这只是在创建一个无限循环。

这行代码: while ((read = getline(&line, &len, list)) != 1)

除非一行包含1字符(只是换行符),否则它将是一个无限循环。POSIX的getline()函数将返回-1(不EOF,即使EOF 平时-1)当文件被完全读取。因此,将该行更改为:

while ((read = getline(&line, &len, list)) != -1)

但是,我看不到您使用该read循环内部的值,因此这样做会更好:

  • 修复1: while (getline(&line, &len, list) != -1)

在该循环中,我看到: printf("%d. %s", item, line);

您可能会发现很旧的实现getline()不包含换行符,在这种情况下,如果要将输出放在单独的行中,则需要放置\n

  • 修复2: printf("%d. %s\n", item, line);

但是,如果使用更现代的实现,它将根据POSIX规范保留换行符。

另外,如果文件中的最后一个“行”未以换行符终止,则您可能仍要添加一个。在这种情况下,您可以保留读取长度,并使用该长度来检测行尾是否有换行符。

也似乎出于某种原因跳过了第一个单词

因为 int letterCount = fscanf(list,"%s",chars);

fscanf将读取文件的第一个单词。现在,文件指针位于该位置(第一个单词的结尾),并且将从该位置进一步读取文件。

因此,从文件中读取第一个单词后,将文件指针重新定位到文件的开头:

  • 修复3:

    int letterCount = fscanf(list,"%s",chars);
    fseek(list, 0, SEEK_SET); // <-- this will reposition the file pointer as required
    

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章