2 回答

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊
eof 就是文件結(jié)束
因?yàn)槲募羔樀阶詈笠粋€(gè)字符時(shí)并不會(huì)觸發(fā)eof,再讀一次讀不到數(shù)據(jù)才觸發(fā)eof,這樣c還保留著上一次的數(shù)據(jù),又被輸出一次,peek()方法是讀取文件指針下一個(gè)位置的值,但并不移動(dòng)文件指針,用在這里很合適
#include<iostream>
#include <fstream>
using namespace std;
void main()
{
fstream io;
char c;
io.open ("a.txt",ios::in);
while (io.peek()!=EOF) //這樣判斷
{
io>>c;
cout<<c;
}
cout<<endl;
io.close();
}

TA貢獻(xiàn)1719條經(jīng)驗(yàn) 獲得超6個(gè)贊
EOF在C++中的定義為:const int EOF = -1;
它這么定義是有道理的:
舉個(gè)例子來說
int ch; //注意:這里定義了ch是int型的,而不是char型的
while((ch = cin.get()) != EOF)
{
cout << ch;
}
cin.get()是讀取輸入流中的一個(gè)字節(jié),但是時(shí)常忽略的,也是必須注意的是:那些C++的設(shè)計(jì)者們將cin.get()設(shè)計(jì)成返回int型,而不是char型,這不是令人挺奇怪的嗎?感覺char ch = cin.get()比較順其自然吧?原因就是為了能夠使cin.get()能夠返回一個(gè)EOF。
因?yàn)閷?duì)于一個(gè)字節(jié)的長(zhǎng)度,已經(jīng)定義了256個(gè)字符了,即擴(kuò)展的ASCII碼,已經(jīng)不能再弄出一個(gè)字節(jié)表示EOF了,而且對(duì)于上面的程序,我們?nèi)绻?56個(gè)字符都得用,那么拿什么與這些字符比較去結(jié)束這個(gè)循環(huán)呢?
那些設(shè)計(jì)者門將cin.get()讀取的char型提升為一個(gè)int型,那么肯定是正的,然后EOF定義為-1,在windows下的ctrl+z表示輸入EOF,即輸入ctrl+z的時(shí)候cin.get()才等于-1,其余的字符輸入的時(shí)候cin.get()是一個(gè)正數(shù)。這是設(shè)計(jì)者門提供EOF的主要原因。
- 2 回答
- 0 關(guān)注
- 688 瀏覽
添加回答
舉報(bào)