C ++ファイルとストリーム
これまで、 iostream 提供する標準ライブラリ cin そして cout それぞれ標準入力からの読み取りと標準出力への書き込みの方法。
このチュートリアルでは、ファイルの読み取りと書き込みの方法を説明します。これには、別の標準C ++ライブラリが必要です。fstream、3つの新しいデータ型を定義します-
シニア番号 | データ型と説明 |
---|---|
1 | ofstream このデータ型は出力ファイルストリームを表し、ファイルの作成とファイルへの情報の書き込みに使用されます。 |
2 | ifstream このデータ型は入力ファイルストリームを表し、ファイルから情報を読み取るために使用されます。 |
3 | fstream このデータ型は一般にファイルストリームを表し、ストリームとifstreamの両方の機能を備えています。つまり、ファイルの作成、ファイルへの情報の書き込み、ファイルからの情報の読み取りを行うことができます。 |
C ++でファイル処理を実行するには、ヘッダーファイル<iostream>と<fstream>をC ++ソースファイルにインクルードする必要があります。
ファイルを開く
ファイルからの読み取りまたはファイルへの書き込みを行う前に、ファイルを開く必要があります。どちらかofstream または fstreamオブジェクトは、書き込み用にファイルを開くために使用できます。また、ifstreamオブジェクトは、読み取り目的でのみファイルを開くために使用されます。
以下は、fstream、ifstream、およびofstreamオブジェクトのメンバーであるopen()関数の標準構文です。
void open(const char *filename, ios::openmode mode);
ここで、最初の引数は開くファイルの名前と場所を指定し、2番目の引数は open() メンバー関数は、ファイルを開くモードを定義します。
シニア番号 | モードフラグと説明 |
---|---|
1 | ios::app 追加モード。そのファイルへのすべての出力は、最後に追加されます。 |
2 | ios::ate 出力用にファイルを開き、読み取り/書き込みコントロールをファイルの最後に移動します。 |
3 | ios::in 読み取るためにファイルを開きます。 |
4 | ios::out 書き込み用にファイルを開きます。 |
5 | ios::trunc ファイルがすでに存在する場合、ファイルを開く前にその内容が切り捨てられます。 |
これらの値の2つ以上を次のように組み合わせることができます ORそれらを一緒に。たとえば、ファイルを書き込みモードで開き、すでに存在する場合にそれを切り捨てたい場合、次の構文になります-
ofstream outfile;
outfile.open("file.dat", ios::out | ios::trunc );
同様に、次のように読み取りと書き込みの目的でファイルを開くことができます。
fstream afile;
afile.open("file.dat", ios::out | ios::in );
ファイルを閉じる
C ++プログラムが終了すると、すべてのストリームが自動的にフラッシュされ、割り当てられたすべてのメモリが解放され、開いているすべてのファイルが閉じられます。ただし、プログラマーは、プログラムを終了する前に、開いているすべてのファイルを閉じることをお勧めします。
以下は、fstream、ifstream、およびofstreamオブジェクトのメンバーであるclose()関数の標準構文です。
void close();
ファイルへの書き込み
C ++プログラミングを実行している間、ストリーム挿入演算子(<<)を使用して情報を画面に出力するのと同じように、プログラムからファイルに情報を書き込みます。唯一の違いは、ofstream または fstream の代わりにオブジェクト cout オブジェクト。
ファイルからの読み取り
ストリーム抽出演算子(>>)を使用してキーボードから情報を入力するのと同じように、ファイルからプログラムに情報を読み込みます。唯一の違いは、ifstream または fstream の代わりにオブジェクト cin オブジェクト。
読み取りと書き込みの例
以下は、読み取りおよび書き込みモードでファイルを開くC ++プログラムです。ユーザーが入力した情報をafile.datという名前のファイルに書き込んだ後、プログラムはファイルから情報を読み取り、それを画面に出力します。
#include <fstream>
#include <iostream>
using namespace std;
int main () {
char data[100];
// open a file in write mode.
ofstream outfile;
outfile.open("afile.dat");
cout << "Writing to the file" << endl;
cout << "Enter your name: ";
cin.getline(data, 100);
// write inputted data into the file.
outfile << data << endl;
cout << "Enter your age: ";
cin >> data;
cin.ignore();
// again write inputted data into the file.
outfile << data << endl;
// close the opened file.
outfile.close();
// open a file in read mode.
ifstream infile;
infile.open("afile.dat");
cout << "Reading from the file" << endl;
infile >> data;
// write the data at the screen.
cout << data << endl;
// again read the data from the file and display it.
infile >> data;
cout << data << endl;
// close the opened file.
infile.close();
return 0;
}
上記のコードをコンパイルして実行すると、次のサンプル入力と出力が生成されます。
$./a.out
Writing to the file
Enter your name: Zara
Enter your age: 9
Reading from the file
Zara
9
上記の例では、外部から行を読み取るgetline()関数や、前のreadステートメントによって残された余分な文字を無視するignore()関数など、cinオブジェクトの追加関数を使用しています。
ファイル位置ポインタ
どちらも istream そして ostreamファイル位置ポインタを再配置するためのメンバー関数を提供します。これらのメンバー関数はseekg ( "seek get")istreamおよび seekp (「シークプット」)ostream用。
seekgとseekpの引数は通常、長整数です。2番目の引数は、シーク方向を示すために指定できます。シーク方向はios::beg (デフォルト)ストリームの先頭を基準にして配置する場合、 ios::cur ストリーム内の現在の位置を基準にして配置する場合、または ios::end ストリームの終わりを基準にして配置します。
ファイル位置ポインターは、ファイルの開始位置からのバイト数としてファイル内の位置を指定する整数値です。「get」ファイル位置ポインタの配置の例は次のとおりです。
// position to the nth byte of fileObject (assumes ios::beg)
fileObject.seekg( n );
// position n bytes forward in fileObject
fileObject.seekg( n, ios::cur );
// position n bytes back from end of fileObject
fileObject.seekg( n, ios::end );
// position at end of fileObject
fileObject.seekg( 0, ios::end );