C++ seekg函數(shù)用法案例詳解
C++ seekg函數(shù)用法詳解
很多時(shí)候用戶(hù)可能會(huì)這樣操作,打開(kāi)一個(gè)文件,處理其中的所有數(shù)據(jù),然后將文件倒回到開(kāi)頭,再次對(duì)它進(jìn)行處理,但是這可能有點(diǎn)不同。例如,用戶(hù)可能會(huì)要求程序在數(shù)據(jù)庫(kù)中搜索某種類(lèi)型的所有記錄,當(dāng)這些記錄被找到時(shí),用戶(hù)又可能希望在數(shù)據(jù)庫(kù)中搜索其他類(lèi)型的所有記錄。
文件流類(lèi)提供了許多不同的成員函數(shù),可以用來(lái)在文件中移動(dòng)。其中的一個(gè)方法如下:
seekg(offset, place);
這個(gè)輸入流類(lèi)的成員函數(shù)的名字 seekg 由兩部分組成。首先是 seek(尋找)到文件中的某個(gè)地方,其次是 "g" 表示 "get",指示函數(shù)在輸入流上工作,因?yàn)橐獜妮斎肓鳙@取數(shù)據(jù)。
要查找的文件中的新位置由兩個(gè)形參給出:新位置將從由 place 給出的起始位置開(kāi)始,偏移 offset 個(gè)字節(jié)。offset 形參是一個(gè) long 類(lèi)型的整數(shù),而 place 可以是 ios 類(lèi)中定義的 3 個(gè)值之一。起始位置可能是文件的開(kāi)頭、文件的當(dāng)前位置或文件的末尾,這些地方分別由常量 ios::beg、ios::cur 和 ios::end 表示。
有關(guān)在文件中移動(dòng)的更多信息將在后面的章節(jié)中給出,目前先來(lái)關(guān)注如何移動(dòng)到文件的開(kāi)頭。要移到文件的開(kāi)始位置,可以使用以下語(yǔ)句:
seekg(0L,ios::beg);
以上語(yǔ)句表示從文件的開(kāi)頭位置開(kāi)始,移動(dòng) 0 字節(jié),實(shí)際上就是指移動(dòng)到文件開(kāi)頭。
注意,如果目前已經(jīng)在文件末尾,則在調(diào)用此函數(shù)之前,必須清除文件末尾的標(biāo)志。因此,為了移動(dòng)到剛讀取到末尾的文件流 dataln 的開(kāi)頭,需要使用以下兩個(gè)語(yǔ)句:
dataIn.clear(); dataIn.seekg(0L, ios::beg);
下面的程序演示了如何倒回文件的開(kāi)始位置。它首先創(chuàng)建一個(gè)文件,寫(xiě)入一些文本,并關(guān)閉文件;然后打開(kāi)文件進(jìn)行輸入,一次讀取到最后,倒回文件開(kāi)頭,然后再次讀取:
//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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++超詳細(xì)講解標(biāo)準(zhǔn)庫(kù)
C++強(qiáng)大的功能來(lái)源于其豐富的類(lèi)庫(kù)及庫(kù)函數(shù)資源。C++標(biāo)準(zhǔn)庫(kù)(C++ Standard Library, 亦可稱(chēng)作,C++標(biāo)準(zhǔn)程序庫(kù))的內(nèi)容總共在50個(gè)標(biāo)準(zhǔn)頭文件中定義。在C++開(kāi)發(fā)中,要盡可能地利用標(biāo)準(zhǔn)庫(kù)完成2022-06-06簡(jiǎn)單實(shí)現(xiàn)C語(yǔ)言2048游戲
這篇文章主要為大家詳細(xì)介紹了簡(jiǎn)單實(shí)現(xiàn)C語(yǔ)言2048游戲,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05C++中的多態(tài)問(wèn)題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理
這篇文章主要介紹了C++中的多態(tài)問(wèn)題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02簡(jiǎn)單說(shuō)說(shuō)STL的內(nèi)存管理
<STL 源碼剖析>將其描述為空間配置器,理由是allocator可以將其它存儲(chǔ)介質(zhì)(例如硬盤(pán))做為stl 容器的存儲(chǔ)空間。由于內(nèi)存是allocator管理的主要部分,因此,本文以STL內(nèi)存管理為出發(fā)點(diǎn)介紹allocator2013-09-09C語(yǔ)言聯(lián)合體Union特點(diǎn)及運(yùn)用全面講解教程
這篇文章主要為大家介紹了C語(yǔ)言聯(lián)合體Union特點(diǎn)及運(yùn)用的全面講解教程有需要深度朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-10-10C語(yǔ)言計(jì)算1/1+1/2+1/3+…+1/n的問(wèn)題
這篇文章主要介紹了C語(yǔ)言計(jì)算1/1+1/2+1/3+…+1/n的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11c語(yǔ)言中實(shí)現(xiàn)數(shù)組幾個(gè)數(shù)求次大值
這篇文章主要介紹了c語(yǔ)言中實(shí)現(xiàn)數(shù)組幾個(gè)數(shù)求次大值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12