【发布时间】:2014-03-26 21:06:08
【问题描述】:
所以我正在用 C 语言编写一个并行数独解决方案检查器,但我似乎在读取普通的旧 .txt 文件时遇到了问题。
下面是要读入文件的代码:
FILE* fp = fopen(argv[1], "r");
if (fp == NULL) {
printf("Cannot open file\n");
return 1;
}
//Begin copying file using fgetc
int c;
while ((c = fgetc(fp)) != EOF) {
for (int i = 0; i < PUZZLE_SIZE; ++i) {
for (int j = 0; j < PUZZLE_SIZE; ++j) {
if (c != -38) { //-38 is newline
//puzzle is a global array of ints
puzzle[i][j] = c - 48; //handles ASCII to int (1-9) conversion
}
}
}
}
fclose(fp);
.txt文件如下:
534678912
672195348
198342567
859761423
426853791
713924856
961537284
287419635
345286179
当我打印 c - 48 时,我得到了预期值;当我在循环内打印拼图[i][j] 时,我再次得到正常值。但是,当我之后查看我的拼图数组时,每个值都设置为 9;对于我的一生,我无法弄清楚为什么。是否存在我不知道的内存/范围问题?
【问题讨论】:
-
if (c != -38) { //-38 is newline我非常怀疑 -->if (c != '\n') { ...}还有puzzle[i][j] = c - 48;-->puzzle[i][j] = c - '0';Btwif (c == '\n) break;更清晰,更健壮,并且避免了嵌套。 -
由于在您为文件中的每个字符、网格的每个单元格执行两个 for 循环时,文件中的最后一个字符恰好是 9...需要检查您的循环逻辑。
-
fgetc()的返回值将是 0..UCHAR_MAX(通常为 255)或 EOF(通常为 -1)范围内的非负整数。在任何已知情况下都不会是 -38。 -
@Pillsy 代码中的编辑可能已经解决了问题,但不应该被批准。回滚是正确的操作。
-
@Taiki 错了。在
fgetc()的特定情况下,手册页明确指出它返回转换为unsigned char或EOF 的字符的值。之所以如此,是因为EOF总是否定的;这允许使用负字符的实现来处理这个问题 - 否则,EOF可能会被错误地解释为有效字符。所以,fgetc()总是返回一个正值,或者一个负常数表示EOF。