[英]fclose function in c, Why fread() works but not fwrite() if you call fclose for file handler
如果我们使用fread()读取文件并且不包含fclose来关闭相同的文件引用,但仍然可以运行,为什么会这样呢。
但是,如果我们忘记在fwrite之后再加上fclose,那么它就行不通了。
顾名思义, fread()
从文件读取数据。 从逻辑上讲,它只有在实际读取数据(将其存储在您提供的缓冲区中)或报告错误后才能返回。 fread()
返回后,即可使用数据。
另一方面, fwrite()
可以在C运行时库,OS和其他地方经历多层缓冲。 fwrite()
在处理fwrite()
数据并将其写到某处时返回 。 在您刷新它( fflush(outfile);
)或关闭它( fclose(outfile);
)之前,无法保证它实际上已写入物理文件。 一旦fwrite()
返回,您就可以对传递给它的数据(已被复制)进行所需的操作,但这只是您可以假设的。
如果您的程序正常终止,它将隐式关闭(并刷新)所有打开的输出文件。 如果您的程序异常终止,则可能不会发生。
(实际上,我认为在某些情况下,即使在fclose()
或fflush()
之后,数据也可能无法物理到达文件中。)
文件访问被缓冲。 当执行fread()
,它只有在读取实际数据后才能返回,但是如果执行fwrite()
则可以在将已写入的数据放入文件缓冲区之后但在将其写入基础文件之前返回。
fclose()
的副作用是刷新文件缓冲区-您也可以在fwrite()
之后使用fflush()
fwrite()
来达到相同的效果。
因为读操作显然必须在返回fread
函数之后完成-实际读取缓冲区中的数据是fread
的后置条件之一,否则您无法确定可以在调用后对缓冲区中的数据做任何有用的事情fread
1 。
fwrite
可以(并且将)进行写缓冲-它会在将其数据传递给操作系统以将其实际记入文件之前在其专用缓冲区中累积数据; 这是可能的(并且很方便),因为就您的程序而言,这件事是完全透明的:数据已经存储在其他缓冲区中,如果您从同一流中回读,则可以在其中找到数据,仍然可以从缓存中获得性能改进。 但是,如果您需要数据立即进入操作系统,则可以使用fflush
。
顺便说一句,即使您没有立即调用fclose
,标准也保证在正常程序终止的情况下,流将自动关闭,因此将刷新其内容。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.