C++ seekg函數(shù)用法案例詳解
C++ seekg函數(shù)用法詳解
很多時(shí)候用戶可能會(huì)這樣操作,打開一個(gè)文件,處理其中的所有數(shù)據(jù),然后將文件倒回到開頭,再次對它進(jìn)行處理,但是這可能有點(diǎn)不同。例如,用戶可能會(huì)要求程序在數(shù)據(jù)庫中搜索某種類型的所有記錄,當(dāng)這些記錄被找到時(shí),用戶又可能希望在數(shù)據(jù)庫中搜索其他類型的所有記錄。
文件流類提供了許多不同的成員函數(shù),可以用來在文件中移動(dòng)。其中的一個(gè)方法如下:
seekg(offset, place);
這個(gè)輸入流類的成員函數(shù)的名字 seekg 由兩部分組成。首先是 seek(尋找)到文件中的某個(gè)地方,其次是 "g" 表示 "get",指示函數(shù)在輸入流上工作,因?yàn)橐獜妮斎肓鳙@取數(shù)據(jù)。
要查找的文件中的新位置由兩個(gè)形參給出:新位置將從由 place 給出的起始位置開始,偏移 offset 個(gè)字節(jié)。offset 形參是一個(gè) long 類型的整數(shù),而 place 可以是 ios 類中定義的 3 個(gè)值之一。起始位置可能是文件的開頭、文件的當(dāng)前位置或文件的末尾,這些地方分別由常量 ios::beg、ios::cur 和 ios::end 表示。
有關(guān)在文件中移動(dòng)的更多信息將在后面的章節(jié)中給出,目前先來關(guān)注如何移動(dòng)到文件的開頭。要移到文件的開始位置,可以使用以下語句:
seekg(0L,ios::beg);
以上語句表示從文件的開頭位置開始,移動(dòng) 0 字節(jié),實(shí)際上就是指移動(dòng)到文件開頭。
注意,如果目前已經(jīng)在文件末尾,則在調(diào)用此函數(shù)之前,必須清除文件末尾的標(biāo)志。因此,為了移動(dòng)到剛讀取到末尾的文件流 dataln 的開頭,需要使用以下兩個(gè)語句:
dataIn.clear(); dataIn.seekg(0L, ios::beg);
下面的程序演示了如何倒回文件的開始位置。它首先創(chuàng)建一個(gè)文件,寫入一些文本,并關(guān)閉文件;然后打開文件進(jìn)行輸入,一次讀取到最后,倒回文件開頭,然后再次讀?。?/p>
//Program shows how to rewind a file. It writes a text file and opens it for reading, then rewinds // it to the beginning and reads it again. #include <iostream> #include <fstream> using namespace std; int main() { // Variables needed to read or write file one character at a time char ch; fstream ioFile("rewind.txt", ios::out); // Open file. if (!ioFile) { cout << "Error in trying to create file"; return 0; } // Write to file and close ioFile << "All good dogs" << endl << "growl, bark, and eat." << endl; ioFile.close(); //Open the file ioFile.open ("rewind.txt", ios::in); if (!ioFile) { cout << "Error in trying to open file"; return 0; } // Read the file and echo to screen ioFile.get(ch); while (!ioFile.fail()) { cout.put(ch); ioFile.get(ch); } //Rewind the file ioFile.clear(); ioFile.seekg(0, ios::beg); //Read file again and echo to screen ioFile.get(ch); while (!ioFile.fail()) { cout.put(ch); ioFile.get(ch); } return 0; }
程序輸出結(jié)果:
All good dogs
growl, bark, and eat.
All good dogs
growl, bark, and eat.
到此這篇關(guān)于C++ seekg函數(shù)用法案例詳解的文章就介紹到這了,更多相關(guān)C++ seekg函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理
這篇文章主要介紹了C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02C語言聯(lián)合體Union特點(diǎn)及運(yùn)用全面講解教程
這篇文章主要為大家介紹了C語言聯(lián)合體Union特點(diǎn)及運(yùn)用的全面講解教程有需要深度朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-10-10c語言中實(shí)現(xiàn)數(shù)組幾個(gè)數(shù)求次大值
這篇文章主要介紹了c語言中實(shí)現(xiàn)數(shù)組幾個(gè)數(shù)求次大值,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12