简体   繁体   中英

Why fprintf doesn't write directly into the file unless fflush() is used?

I have written a daemon that writes a value in a file. What I have observed is that when I keep writing on a file, there is nothing visible in the file. in other hand, If I use fflush() method then the characters are visible in the file. Why fflush() makes a difference?

Because it's buffered . That means all writes are stored in a buffer in memory until the buffer is flushed. For printf and friends it's when it has either a newline, or you explicitly call fflush , or of course if the buffer becomes full.

By default, stdio is fully buffered, unless it's writing to a terminal, in which case it's line-buffered, or stderr, which is not buffered at all.

You can disable buffering with the setbuf() function.

setbuf(fp, NULL);

fprintf is an IO routine provided by the libc, it use caching mechanism by default, before doing a real write into files.

Characters are normally accumulated and transmitted asynchronously to the file in a block, so the cache must exceed the libc(stdio) internal buffer size (BUFSIZE, #defined in stdio.h) or when a fflush() has occurred.

If you want to minimize the caching i suggest you to use O_DIRECT or O_SYNC flags for your open call, but there is some restrictions: you must ensure alignment of your buffers and other stuffs. Read the O_DIRECT section of man 2 open .

you may also read this for further informations on how to control libc buffering.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM