16
FILE *out=fopen64("text.txt","w+");
unsigned int write;
char *outbuf=new char[write];
//fill outbuf
printf("%i\n",ftello64(out));
fwrite(outbuf,sizeof(char),write,out);
printf("%i\n",write);
printf("%i\n",ftello64(out));

输出:

0
25755
25868

到底是怎么回事?write 设置为 25755,我告诉 fwrite 将这么多字节写入一个文件,它在开头,然后我在 25755 之外的位置?

4

4 回答 4

29

如果您使用的是 DOSish 系统(例如 Windows)并且文件未以二进制模式打开,则行尾将自动转换,并且每个“行”将添加一个字节。

因此,指定"wb"为模式,而不是"w"像@caf 指出的那样。它对类 Unix 平台没有影响,并且会在其他平台上做正确的事情。

例如:

#include <stdio.h>

#define LF 0x0a

int main(void) {
    char x[] = { LF, LF };

    FILE *out = fopen("test", "w");

    printf("%d", ftell(out));
    fwrite(x, 1, sizeof(x), out);
    printf("%d", ftell(out));

    fclose(out);
    return 0;
}

使用 VC++:

C:\Temp> cl yc
Microsoft (R) 32 位 C/C++ 优化编译器版本 15.00.21022.08 用于 80x86
版权所有 (C) 微软公司。版权所有。

yc
Microsoft (R) 增量链接器版本 9.00.21022.08
版权所有 (C) 微软公司。版权所有。

/out:y.exe

C:\Temp> y.exe
04

使用 Cygwin gcc:

/cygdrive/c/Temp $ gcc yc -o y.exe

/cygdrive/c/Temp $ ./y.exe
02
于 2009-10-19T00:18:05.417 回答
4

这可能取决于您打开文件的模式。如果将其作为文本文件打开,则\n可能会像\r\n在 DOS/Windows 系统中那样编写。但是,ftello64()可能只给出二进制文件指针,这将计入写入的额外\r字符。尝试清除outbuf[]任何\n数据或尝试将输出文件打开为二进制文件("wb"而不是"w")。

于 2009-10-19T00:21:08.657 回答
2

该变量write未初始化,因此数组的大小和写入的数量基本上是随机的。

于 2009-10-19T00:32:36.083 回答
0

有趣的。在 Windows VC++ 上运行良好,尽管ftello64被替换为ftell.

于 2009-10-19T00:28:22.557 回答