http://zhidao.baidu.com/link?url=_fl0cOQFJ6x9usD9FBHlnopdCWJK0qhE_D8CLU3R8KDUfvbgslaYv5RAUUrbvPvFp6_JUVFl3QL-fzvp2phqRa
它这么定义是有道理的:
举个例子来说int ch; //注意:这里定义了ch是int型的,而不是char型的
while((ch = cin.get()) != EOF)
{
cout << ch;
}
cin.get()是读取输入流中的一个字节,但是时常忽略的,也是必须注意的是:那些C++的设计者们将cin.get()设计成返回int型,而不是char型,这不是令人挺奇怪的吗?感觉char ch = cin.get()比较顺其自然吧?原因就是为了能够使cin.get()能够返回一个EOF。
因为对于一个字节的长度,已经定义了256个字符了,即扩展的ASCII码,已经不能再弄出一个字节表示EOF了,而且对于上面的程序,我们如果256个字符都得用,那么拿什么与这些字符比较去结束这个循环呢?
那些设计者门将cin.get()读取的char型提升为一个int型,那么肯定是正的,然后EOF定义为-1,在windows下的ctrl+z表示输入EOF,即输入ctrl+z的时候cin.get()才等于-1,其余的字符输入的时候cin.get()是一个正数。这是设计者门提供EOF的主要原因。