namespace: std ifstream – 從已有的文件讀 ofstream – 向文件寫內容 fstream - 打開文件供讀寫
成員函數open()實現打開文件的操作,從而將數據流和文件進行關聯,通過ofstream,ifstream,fstream對象進行對文件的讀寫操作
void open ( const char * filename, ios_base::openmode mode = ios_base::in | ios_base::out ); void open(const wchar_t *_Filename, ios_base::openmode mode= ios_base::in | ios_base::out, int PRot = ios_base::_Openprot);參數: filename 操作文件名 mode 打開文件的方式 prot 打開文件的屬性 打開文件的方式在iOS類(所以流式I/O的基類)中定義,有如下幾種方式: 打開文件的屬性同樣在ios類中也有定義:
很多程序中,可能會碰到ofstream out(“Hello.txt”), ifstream in(“…”),fstream foi(“…”)這樣的的使用,并沒有顯式的去調用open()函數就進行文件的操作,直接調用了其默認的打開方式,因為在stream類的構造函數中調用了open()函數,并擁有同樣的構造函數,所以在這里可以直接使用流對象進行文件的操作;
打開文件時一定要檢查文件是否已經打開 不操作文件一定關閉文件 getline(infile,s)將文件寫入string中
#include<iostream>#include<fstream>#include<string>using namespace std;int main(){ string filename = "1.txt"; fstream infile(filename, ios::in); if (!infile) { throw runtime_error("file cannot open"); return -1; } else { string s; while (!infile.eof()) { getline(infile, s); cout << s << endl; } } infile.close(); return 0;}#include<iostream>#include<fstream>#include<string>using namespace std;int main(){ string filename = "1.txt"; ofstream outfile; outfile.open(filename, ios::out | ios::app); if (!outfile) { throw runtime_error("file cannot open"); } else { outfile << "111" << "222" << endl; outfile.close(); }}狀態標志符的驗證(Verification of state flags) 除了eof()以外,還有一些驗證流的狀態的成員函數(所有都返回bool型返回值): bad() 如果在讀寫過程中出錯,返回 true 。例如:當我們要對一個不是打開為寫狀態的文件進行寫入時,或者我們要寫入的設備沒有剩余空間的時候。 fail() 除了與bad() 同樣的情況下會返回 true 以外,加上格式錯誤時也返回true ,例如當想要讀入一個整數,而獲得了一個字母的時候。 eof() 如果讀文件到達文件末尾,返回true。 good() 這是最通用的:如果調用以上任何一個函數返回true 的話,此函數返回 false 。 要想重置以上成員函數所檢查的狀態標志,你可以使用成員函數clear(),沒有參數。
我們可以通過使用以下成員函數來讀出或配置這些指向流中讀寫位置的流指針: tellg() 和 tellp() 這兩個成員函數不用傳入參數,返回pos_type 類型的值(根據ANSI-C++ 標準) ,就是一個整數,代表當前get 流指針的位置 (用tellg) 或 put 流指針的位置(用tellp). seekg() 和seekp() 這對函數分別用來改變流指針get 和put的位置。兩個函數都被重載為兩種不同的原型: seekg ( pos_type position ); seekp ( pos_type position ); 使用這個原型,流指針被改變為指向從文件開始計算的一個絕對位置。要求傳入的參數類型與函數 tellg 和tellp 的返回值類型相同。 seekg ( off_type offset, seekdir direction ); seekp ( off_type offset, seekdir direction ); 使用這個原型可以指定由參數direction決定的一個具體的指針開始計算的一個位移(offset)。它可以是:
使用這個原型可以指定由參數direction決定的一個具體的指針開始計算的一個位移(offset)。它可以是: 流指針 get 和 put 的值對文本文件(text file)和二進制文件(binary file)的計算方法都是不同的,因為文本模式的文件中某些特殊字符可能被修改。由于這個原因,建議對以文本文件模式打開的文件總是使用seekg 和 seekp的第一種原型,而且不要對tellg 或 tellp 的返回值進行修改。對二進制文件,你可以任意使用這些函數,應該不會有任何意外的行為產生。
4.二進制文件 在二進制文件中,使用<< 和>>,以及函數(如getline)來操作符輸入和輸出數據,沒有什么實際意義,雖然它們是符合語法的。 文件流包括兩個為順序讀寫數據特殊設計的成員函數:write 和 read。第一個函數 (write) 是ostream 的一個成員函數,都是被ofstream所繼承。而read 是istream 的一個成員函數,被ifstream 所繼承。類 fstream 的對象同時擁有這兩個函數。它們的原型是: write ( char * buffer, streamsize size ); read ( char * buffer, streamsize size ); 這里 buffer 是一塊內存的地址,用來存儲或讀出數據。參數size 是一個整數值,表示要從緩存(buffer)中讀出或寫入的字符數。
#include<iostream>#include<fstream>using namespace std;int main(){ char *filename = "1.txt"; char *buffer; long size,m; ifstream infile(filename,ios::in | ios::binary | ios::ate); size = infile.tellg(); buffer = new char[size]; infile.seekg(0, ios::beg); infile.read(buffer, size); infile.close(); cout << buffer << endl; cout << "The complete file is in a buffer" << endl; delete[] buffer; return 0;}新聞熱點
疑難解答
圖片精選