Reputation: 564
A question about this has been asked here End of File (EOF) in C but it still doesn't completely solve my problem.
EOF
makes sense to me in any datastream which is not stdin
, for example if I have some data.txt
file, fgetc()
will read all the chars and come to the end of file and return -1
.
What I don't understand is the concept of EOF
in stdin
. If I use getchar()
, it will wait for me to enter something, so if there is NOTHING written, End of File, (EOF
) is not returned automatically?
So is it that only the user can invoke EOF
in stdin
by pressing Ctrl+Z?
If so then what are some of the uses of EOF
in stdin
? I guess it tells the program to continue reading until the user invokes end of file? is this it?
Thank you
Upvotes: 27
Views: 49902
Reputation: 53006
so if there is NOTHING written, End of File, (EOF) is not returned automatically?
No, it's not. It should be sent by the user.
So is it that only the user can invoke
EOF
instdin
by pressing Ctrl+Z?
Yes, you can set the EOF
indicator for stdin
with a special key combination you can input in the console, for linux console that is Ctrl+D and for windows it's Ctrl+Z.
If so then what are some of the uses of
EOF
instdin
? I guess it tells the program to continue reading until the user user invokes end of file? is this it?
The use of it depends on whether you instruct the user to input the EOF
explicitly or not, for example, I think python
console will tell you something like Press Ctrl+D or type quit() to exit
.
And EOF
is not necessarily -1
it's a macro and you should always use it to test for the EOF
indicator. And more importantly EOF
is not a character, it's a special value that indicates that the End Of File indicator is set.
Also, getchar()
is equivalent to fgetc(stdin)
.
Upvotes: 32
Reputation: 10238
The file stdin
is not always the user typing on the keyboard. If you redirect input to your program, it can be just a normal file.
program.exe <input-from-file.txt
What may be confusing you is that no giving input into a console window does not mark the end of the input. But think it the other way round: how could a user respond so quickly that the program would not terminate before it if the console would not do some buffering for the user? After pressing Enter the user says this is a line of input. In other words: a program running in a console window always waits for the next input to come.
Most programs define a special phrase to end a console session. You probably know exit
.
Upvotes: 0
Reputation: 134326
In linux bash, if you press CTRL+D, it will generate EOF
.
In Windows, the equivalent is CTRL+Z
So, no, if nothing written to the terminal, that does not generate EOF
automatically. The scanning function is in wait state then. So, without having any other inputs, in wait state, if CTRL+D is pressed, the key press is translated [by the terminal driver] to EOF
.Note
Usually, once you key in some value and press the ENTER key, the scannning function starts scanning. To feed an input for producing EOF
, you need to press CTRL+D.
Related: Please reaed the wiki entry for EOF
Note: With thanks to Mr Drew for the clarification.
Upvotes: 10
Reputation: 72226
stdin
is a stream, data is not available until the user presses some keys. A file on the disk already has (a fixed amount of) content.
When reading from stdin
, if getchar()
doesn't wait for the user to input something then the program will always get EOF
. That will make it impossible to use stdin
as an input file.
Because getchar()
waits for the user to input something there is no way to signal the input completed; that's why the operating systems provide a combination of keys that have this special meaning when they are pressed on the console.
Windows uses CtrlZ and Unix-like OSes (including OSX) use CtrlD for this purpose.
Upvotes: 2