Mcs
Mcs

Reputation: 564

End of File in stdin

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

Answers (4)

Iharob Al Asimi
Iharob Al Asimi

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 in stdin 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 in stdin? 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

Wolf
Wolf

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

Sourav Ghosh
Sourav Ghosh

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

axiac
axiac

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

Related Questions