C++的文件IO流
C++根据文件内容的数据格式分为二进制文件和文本文件。采用文件流对象操作文件的一般步骤:
- 定义一个文件流对象
ifstream ifile(只输入用)
ofstream ofile(只输出用)
fstream iofile(既输入又输出用) - 使用文件流对象的成员函数打开一个磁盘文件,使得文件流对象和磁盘文件之间建立联系
- 使用提取和插入运算符对文件进行读写操作,或使用成员函数进行读写
- 关闭文件
注意使用文件流对象的时候要包 <fstream>头文件
上面说到, 文件分为文本文件和二进制文件, 那么两种文件的读写方式势必也不一样
二进制文件: 字节流 读写效率高, 可读性差 (没有经过编码的二进制数据, 看起来都是乱码)
文本文件: 字符流 读写效率低, 可读性好 (编码后的可读字符)
1. 按照字符流读入
字符流读入三种方式 : >> get getline
下面给一个例子体会一下 :
文件内容如下 :
代码 :
void test2() {
ifstream fin;
fin.open("test.txt");
//也可以创建的时候直接打开文件
//ifstream fin("test.txt");
//判断文件是否打开
if (!fin.is_open()) {
cout << "file open failed !" << endl;
return;
}
//按照字符流读入
// >> getline get
int a;
string str;
//遇到(换行/空格)结束
fin >> a;
fin >> str;
char arr[100];
char arr2[100];
char ch;
//换行作为结束标记, 不读入
fin.get(ch);
fin.get(arr, 99); //99是读入字符个数
fin.get(ch);
fin.getline(arr2, 99); //99也是读入个数
}
调试结果如下 :
我们可以看到, 文件中的内容读到了变量中
在使用get, getline的时候, 要注意上一行的换行符有没有读入, 如果上一行有换行而且没有被读入的时候, 使用get读取一个字符把换行符吸收即可, 使用>>的话则不用管
2. 按照字节流读入
字节流读入方式 : read
指定读入字节数, 不关心数据类型
还是刚才的文件, 我们以字节流方式读入
void test2() {
ifstream fin;
fin.open("test.txt");
//也可以创建的时候直接打开文件
//ifstream fin("test.txt");
//判断文件是否打开
if (!fin.is_open()) {
cout << "file open failed !" << endl;
return;
}
char arr[100];
//按照字节流读入 read
//指定读入7个字节, 不关心数据类型
fin.read(arr, 7);
}
结果如下 :
我们可以看到确实读进来了7个字节的数据, 一个int和三个char类型, 由于没有 ‘\0’ 作为结束标志, 所以字符串不可见
3. 按照字符流写入
还是刚才的文件, 这次我们来进行字符流的写入
struct A {
char name[30];
int id;
};
void test3() {
ofstream fout("test.txt");
A a;
strcpy(a.name, "monster");
a.id = 2000;
//按照字符流写
fout << a.name << endl;
fout << a.id << endl;
//即使不手动关闭, 他也会调析构关闭
fout.close();
//读入
A b;
ifstream fin("test.txt");
fin >> b.name;
fin >> b.id;
fin.close();
}
代码运行前的文件 :
运行后 :
我们可以看到, 数据被写入
再看看能不能读出来
调试结果 :
可以读出来
4. 按照字节流写入
如果要打开的文件不存在, 会自动创建
void test4() {
A a;
strcpy(a.name, "monster");
a.id = 2000;
//字节流
ofstream fout("test.binary.txt");
if (!fout.is_open()) {
return;
}
//强转成char* 符合参数类型, 然后sizeof(A)是要写入的字节数
fout.write((char*)&a, sizeof(A));
fout.close();
A c;
//模式mode: binary : 按照二进制读内容
ifstream fin("test.binary.txt", ifstream::binary);
fin.read((char*)&c, sizeof(A));
fin.close();
}
代码运行后, 自动创建文件, 内容如下 :
可以看到, 二进制文本可读性就这是这样
注意看上面二进制读入时, 需要指定二进制模式
可以看到正确读出
那么为什么要强转成char*, 因为函数的参数就是char*, 下面是官方的函数接口