файловая операция
20.0 Предисловие
Данные, сгенерированные во время работы программы, являются временными данными и будут выпущены после завершения работы программы.
Данные могут быть сохранены через файлы .
Файловые операции в C++ должны включать заголовочный файл — <fstream> .
Существует два типа файлов:
- Текстовые файлы — файлы хранятся на вашем компьютере в виде текста в формате ASCII.
- Двоичные файлы . Файлы хранятся на компьютере в двоичной текстовой форме и, как правило, не могут быть прочитаны пользователем напрямую.
Три категории файловых операций:
ofstream
: операция записиifstream
: операция чтенияfstream
: операции чтения и записи
20.1 Текстовые файлы
20.1.1 Запись файлов
Шаги для записи файла следующие:
- включить заголовочный файл
#include<fstream>
- Создать объект потока
ofstream ofs;
- Откройте файл
ofs.open("文件路径,打开方式");
или создайте файл, если он не существует. - записать данные
ofs<<"写入的数据";
- закрыть файл
ofs.close();
Метод открытия:
Примечание . Метод открытия файла можно использовать в сочетании с |
операторами.
Например, напишите файл, используя двоичный файл ios::binary | ios::out
.
Пример:
#include<iostream>
#include<fstream> //头文件包含
using namespace std;
//写文件
void test1_01()
{
//1.头文件
//2.创建流对象
ofstream ofs; //out file stream
//3.指定打开方式
ofs.open("test.txt", ios::out); //如果没有此文件,会默认创建到和源文件相同的文件夹下。
//4.写内容
ofs << "姓名:张三" << endl;
ofs << "性别:男" << endl;
ofs << "年龄:18" << endl;
//5.关闭文件
ofs.close();
}
int main()
{
test1_01();
system("pause");
return 0;
}
Подведем итог:
- Файловые операции должны включать файлы заголовков
<fstream>
. - Запись файлов может использовать
ofstream
классы илиfstream
классы. - Чтобы открыть файл, вам нужно указать путь для работы с файлом и способ его открытия.
- Используйте
<<
для записи данных в файл. - По завершении операции закройте файл.
20.1.2 Чтение файлов
Шаги для чтения файла следующие:
- включить заголовочный файл
#include<fstream>
- Создать объект потока
ifstream ifs;
- Откройте файл и оцените, успешно ли он открыт
ifs.open("文件路径,打开方式");
. - Чтение данных - четыре способа.
- Закройте файл
ifs.close();
.
Четыре способа:
char buf[1024] = { 0 }; ifs >> buf
, читать данные в файле в buf в виде символов и останавливаться, когда он встречает пробел или возврат каретки, а пробел или возврат каретки не будут прочитаны. Возвращает false, если был прочитан конец файла.char buf[1024] = { 0 };ifs.getline(buf, sizeof(buf),'\n')
, sizeof(buf) указывает максимальную длину ожидаемых данных для чтения. Когда количество прочитанных байтов данных равно этому значению или прочитан конец файла, возвращается значение false; '\n' – это терминатор. это может быть указано При чтении Когда указанный символ извлекается, чтение останавливается на этот раз, и '\n' может указать, чтобы читать одну строку данных каждый раз. (Примечание: остановка чтения не возвращает false)string buf; getline(ifs, buf,'\n')
, функция похожа на 2, но синтаксис другой, иstring
нужно добавить заголовочный файл.char c; (c = ifs.get())
, Чтение символов в данных последовательно, необходимо вручную добавить условие завершения.
#include<iostream>
#include<fstream>
#include<string>
using namespace std;
void read_01()//第一种
{
ifstream ifs;
ifs.open("test.txt", ios::in);
if (!ifs.is_open())
{
cout << "文件打开失败" << endl;
return;
}
cout << "第一种" << endl;
while (ifs.eof()) //会依次读取,遇到空格或者回车计算一次读取停止,并且当访问到末尾符时结束
{
char buf[1024] = {
0 };
ifs>>buf;
cout << buf << endl;
}
ifs.close();
}
void read_02()
{
ifstream ifs;
ifs.open("test.txt", ios::in);
if (!ifs.is_open())
{
cout << "文件打开失败" << endl;
return;
}
cout << "第二种" << endl;
char buf[1024] = {
0 };
while(ifs.getline(buf, sizeof(buf),'\n'))//'\n'是指每次读取到回车为止,默认也是回车,如果更改为其他的,会有不同效果。
{
cout << buf << endl;
//cout << buf;
}
ifs.close();
}
void read_03()
{
ifstream ifs;
ifs.open("test.txt", ios::in);
if (!ifs.is_open())
{
cout << "文件打开失败" << endl;
return;
}
cout << "第三种" << endl;
string buf;
while(getline(ifs, buf,'\n')) //getline需要string头文件,功能和第二种差不多,语法不同。
{
cout << buf << endl;
//cout << buf ;
}
ifs.close();
}
void read_04()
{
ifstream ifs;
ifs.open("test.txt", ios::in);
if (!ifs.is_open())
{
cout << "文件打开失败" << endl;
return;
}
cout << "第四种" << endl;
char c;
while ((c = ifs.get()) != EOF) //end of file,文件尾,这是一个字符一个字符读,并判断当读取到文件尾停止。
{
cout << c ;
}
cout << endl;
ifs.close();
}
void test2_01()
{
//1.包含头文件
//2.创建流对象
//3.打开文件,并且判断是否打开成功
//4.读数据
read_01();
read_02();
read_03();
read_04();
//5.关闭文件
}
int main()
{
test2_01();
system("pause");
return 0;
}
20.2 Двоичные файлы
Чтение и запись файлов в двоичном режиме,
Открыть с помощью, чтобы быть указано как ios::binary
.
20.2.1 Запись файлов
Запись файлов в двоичном режиме в основном использует потоковые объекты для вызова функций-членов.write
Прототип функции: ostream& write(const char* buffer , int len);
Объяснение параметра: Указатель символа buffer
указывает на область хранения в памяти, которая len
представляет собой количество байтов для чтения и записи.
Пример:
#include<iostream>
#include<fstream> //头文件包含
using namespace std;
class Person
{
public:
char m_Name[64]; //姓名 , 用char不用string,char比string底层,string容易出问题.
int m_Age;
};
void test3_01()
{
ofstream ofs("person.txt", ios::binary | ios::out); //可以直接在创建时这样写,省去.open()操作.
//ofs.open("person.txt", ios::binary | ios::out);
Person p = {
"张三",18 };
ofs.write((const char*)&p, sizeof(Person)); //&p就是地址, ofs传入的是const char*型的指针,所以需要转换类型.
ofs.close();
//看起来可能会奇怪,乱码,因为二进制格式,不会影响使用二进制来读。
}
int main3()
{
test3_01();
system("pause");
return 0;
}
20.2.2 Чтение файлов
Чтение файлов в двоичном режиме в основном использует потоковые объекты для вызова функций-членов read
.
Прототип функции:ostream& read(char* buffer , int len);
Объяснение параметра: Указатель символа buffer
указывает на место для хранения в памяти, которое len
представляет собой количество прочитанных и записанных байтов.
Пример:
#include<iostream>
#include<fstream> //头文件包含
using namespace std;
class Person2
{
public:
char m_Name[64];
int m_Age;
};
ostream& operator<<(ostream& cout,Person2& p)
{
cout << "名字:" << p.m_Name << " 年龄:" << p.m_Age << endl;
return cout;
}
void test4_01()
{
ifstream ifs("person.txt", ios::binary | ios::in);
if (!ifs.is_open())
{
cout << "文件打开失败" << endl;
return;
}
Person2 p;
ifs.read((char*) &p, sizeof(Person2));
cout << p << endl;
ifs.close();
//文件打开不正常,但是读的内容是正常的,这可能就是二进制文件的特点吧。
}
int main()
{
test4_01();
system("pause");
return 0;
}