I am simply trying to read each character from a file and print them in the screen. For testing, I tried to print ascii value in a console screen first before printing character
Do not read while not eof()
1. That's not a proper reading loop.
Read while reading succeeds.
int x;
while ((x = in.get()) != EOF)
{
cout << x << endl;
}
Testing for in.eof()
will not guarantee reading will succeed. When you test for in.eof()
you're actually testing if the previous read operation tried to read past the end of the file. This is bad, because it means the previous read operation failed. It failed and you didn't care, and just pressed on to use the value it returned even though it failed.
When in.get()
fails, it returns the constant EOF
. That's what you should be checking. If in.get()
fails, you don't want to continue with your loop as if it succeeded.
1 Same goes for while good()
or while not bad()
.