我在Windows上遇到了一些文件写入失败的问题。我将其简化为下面的示例:
FILE* f = fopen("test.out", "r+b");
fseek(f, -1, SEEK_END); // one byte before the end
printf("read byte: %c\n", fgetc(f)); // read the last byte; now at the end
printf("attempting write: %d\n", fputs("text", f));这正确地输出了test.out的最后一个字节,但是fputs失败并返回-1。这些类似的例子都很好:
这些似乎都表明了流错误或eof问题,但是ferror(f)和feof(f)都返回0,直到失败的fputs()。之后,ferror(f)不是零,但errno是0,所以我不知道问题是什么。
我只在Visual 2008和GCC 4.7.2 (MinGW)的Windows上看到这种情况。在Linux上,相同的代码运行时没有错误。
发布于 2013-06-13 20:10:20
C标准要求您在从“读取模式”切换到“写入模式”时进行查找,反之亦然,除非某些特殊情况通常不值得列举。
一个实现(比如我几年前为BSD编写的实现,或者Linux实现)可能比需要的更宽容,从而使您的代码“正常工作”。(这真的很容易,您只需要在实现中保留两个单独的计数器,而不是一个合并的计数器。)但是,标准并不要求实现是友好的,而Windows的实现不是友好的。
https://stackoverflow.com/questions/17095681
复制相似问题