C++ 檔案和流
C++ 檔案和流
到目前為止,我們已經使用了 iostream 標準庫,它提供了 cin 和 cout 方法分別用於從標準輸入讀取流和向標準輸出寫入流。
本教程介紹如何從檔案讀取流和向檔案寫入流。這就需要用到 C++ 中另一個標準庫 fstream,它定義了三個新的資料型別:
資料型別 | 描述 |
---|---|
ofstream | 該資料型別表示輸出檔案流,用於建立檔案並向檔案寫入資訊。 |
ifstream | 該資料型別表示輸入檔案流,用於從檔案讀取資訊。 |
fstream | 該資料型別通常表示檔案流,且同時具有 ofstream 和 ifstream 兩種功能,這意味著它可以建立檔案,向檔案寫入資訊,從檔案讀取資訊。 |
要在 C++ 中進行檔案處理,必須在 C++ 原始碼檔案中包含標頭檔案 <iostream> 和 <fstream>。
開啟檔案
在從檔案讀取資訊或者向檔案寫入資訊之前,必須先開啟檔案。ofstream 和 fstream 物件都可以用來開啟檔案進行寫操作,如果只需要開啟檔案進行讀操作,則使用 ifstream 物件。
下面是 open() 函式的標準語法,open() 函式是 fstream、ifstream 和 ofstream 物件的一個成員。
void open(const char *filename, ios::openmode mode);
在這裡,open() 成員函式的第一引數指定要開啟的檔案的名稱和位置,第二個引數定義檔案被開啟的模式。
模式標誌 | 描述 |
---|---|
ios::app | 追加模式。所有寫入都追加到檔案末尾。 |
ios::ate | 檔案開啟後定位到檔案末尾。 |
ios::in | 開啟檔案用於讀取。 |
ios::out | 開啟檔案用於寫入。 |
ios::trunc | 如果該檔案已經存在,其內容將在開啟檔案之前被截斷,即把檔案長度設為 0。 |
您可以把以上兩種或兩種以上的模式結合使用。例如,如果您想要以寫入模式開啟檔案,並希望截斷檔案,以防檔案已存在,那麼您可以使用下面的語法:
ofstream outfile; outfile.open("file.dat", ios::out | ios::trunc );
類似地,您如果想要開啟一個檔案用於讀寫,可以使用下面的語法:
ifstream afile; afile.open("file.dat", ios::out | ios::in );
關閉檔案
當 C++ 程式終止時,它會自動關閉重新整理所有流,釋放所有分配的記憶體,並關閉所有開啟的檔案。但程式設計師應該養成一個好習慣,在程式終止前關閉所有開啟的檔案。
下面是 close() 函式的標準語法,close() 函式是 fstream、ifstream 和 ofstream 物件的一個成員。
void close();
寫入檔案
在 C++ 程式設計中,我們使用流插入運算子( << )向檔案寫入資訊,就像使用該運算子輸出資訊到螢幕上一樣。唯一不同的是,在這裡您使用的是 ofstream 或 fstream 物件,而不是 cout 物件。
讀取檔案
在 C++ 程式設計中,我們使用流提取運算子( >> )從檔案讀取資訊,就像使用該運算子從鍵盤輸入資訊一樣。唯一不同的是,在這裡您使用的是 ifstream 或 fstream 物件,而不是 cin 物件。
讀取 & 寫入例項
下面的 C++ 程式以讀寫模式開啟一個檔案。在向檔案 afile.dat 寫入使用者輸入的資訊之後,程式從檔案讀取資訊,並將其輸出到螢幕上:
例項
當上面的程式碼被編譯和執行時,它會產生下列輸入和輸出:
$./a.out Writing to the file Enter your name: Zara Enter your age: 9 Reading from the file Zara 9
上面的例項中使用了 cin 物件的附加函式,比如 getline()函式從外部讀取一行,ignore() 函式會忽略掉之前讀語句留下的多餘字元。
檔案位置指標
istream 和 ostream 都提供了用於重新定位檔案位置指標的成員函式。這些成員函式包括關於 istream 的 seekg("seek get")和關於 ostream 的 seekp("seek put")。
seekg 和 seekp 的引數通常是一個長整型。第二個引數可以用於指定查詢方向。查詢方向可以是 ios::beg(預設的,從流的開頭開始定位),也可以是 ios::cur(從流的當前位置開始定位),也可以是 ios::end(從流的末尾開始定位)。
檔案位置指標是一個整數值,指定了從檔案的起始位置到指標所在位置的位元組數。下面是關於定位 "get" 檔案位置指標的例項: