许多系统中的标准输入/输出库都允许程序打开一个文件,同时进行写入和读出的操作:

FILE * fp;  
fp = fopen(file, "r+");

上面的例子代码打开了文件名由变量 file 指定的文件,对于存取权限的设定表明程序希望对这个文件进行输入和输出操作。

编程者也许认为,程序一旦执行上述操作完毕,就可以自由地交错进行读出和写入操作。遗憾的是,事实总是难随人愿,为了保持与过去不能同时进行读写操作的程序的向下兼容性,一个输入操作不能随后直接紧跟着一个输出操作,反之亦然。如果要同时进行输入和输出操作,必须在其中插入 fseek 函数的调用(只适用于windows平台)

下面的程序片段似乎更新了一个顺序文件中选定的记录:

FILE * fp;  
struct record rec;
//... ...
while (fread((char *)&rec, sizeof(rec), 1, fp) == 1)
{
/* 对rec执行某些操作 */
if (/* rec 必须被重新写入 */)
{
fseek(fp, -(long)sizeof(rec), 1);
fwrite((char *)&rec, sizeof(rec), 1, fp);
}
}

这段代码乍看上去没有问题。但是实际上出错的方式令人难以察觉。如果一个记录需要被重新写入,也就是是说,fwrite 函数得到执行,对这个文件执行的下一个操作将是循环开始的 fread 函数。因为在 fwrite 函数调用与 fread 函数调用之间缺少一个 fseek 函数的调用,所以无法进行上述操作。解决办法如下:

FILE * fp;  
struct record rec;
//... ...
while (fread((char *)&rec, sizeof(rec), 1, fp) == 1)
{
/* 对rec执行某些操作 */
if (/* rec 必须被重新写入 */)
{
fseek(fp, -(long)sizeof(rec), 1);
fwrite((char *)&rec, sizeof(rec), 1, fp);
fseek(fp, 0L, 1); //新增 fseek
}
}

第二个 fseek 函数虽然看上去什么也没有做,但它改变了文件的状态,使得文件现在可以正常地读取了。