I'm just learning C with Kernighan and Ritchie's book; I'm in the basics of the fourth chapter (functions stuff). The other day I became curious about the sleep()
function, so tried to use it like this:
#include <stdio.h>
#include <unistd.h>
int main(void)
{
printf(" I like cows.");
sleep(5);
return 0;
}
The problem is the output of the program, it looks like it does the sleep()
first and then the printf()
, in other words, it waits five seconds and then prints the string. So I thought, maybe the program gets to sleep()
so fast that it doesn't let printf()
have his work done like I want, that is print the string and then sleep.
How can I show the string and then put the program to sleep? The compiler is GCC 3.3.5 (propolice) in OpenBSD 4.3.
PS I don't know how you put here the preprocessor lines correctly.
printf()
writes to stdout
(the default output stream) which is usually line buffered. The buffer isn't flushed by the time sleep
is called so nothing is displayed, when the program exits all streams are automatically flushed which is why it prints right before exiting. Printing a newline will usually cause the stream to be flushed, alternatively you could use the fflush
function:
int main(void)
{
printf(" I like cows.\n");
sleep(5);
return 0;
}
or:
int main(void)
{
printf(" I like cows.");
fflush(stdout);
sleep(5);
return 0;
}
If you are printing to a stream that is not line buffered, as may be the case if stdout
is redirected or you are writing to a file, simply printing a newline probably won't work. In such cases you should use fflush
if you want the data written immediately.