Учебные заметки по C++ Операция с 20 файлами

20.0 Предисловие

Данные, сгенерированные во время работы программы, являются временными данными и будут выпущены после завершения работы программы.

Данные могут быть сохранены через файлы .

Файловые операции в C++ должны включать заголовочный файл — <fstream> .
Существует два типа файлов:

  1. Текстовые файлы — файлы хранятся на вашем компьютере в виде текста в формате ASCII.
  2. Двоичные файлы . Файлы хранятся на компьютере в двоичной текстовой форме и, как правило, не могут быть прочитаны пользователем напрямую.

Три категории файловых операций:

  1. ofstream: операция записи
  2. ifstream: операция чтения
  3. fstream: операции чтения и записи

20.1 Текстовые файлы

20.1.1 Запись файлов

Шаги для записи файла следующие:

  1. включить заголовочный файл#include<fstream>
  2. Создать объект потокаofstream ofs;
  3. Откройте файл ofs.open("文件路径,打开方式");или создайте файл, если он не существует.
  4. записать данныеofs<<"写入的数据";
  5. закрыть файл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 Чтение файлов

Шаги для чтения файла следующие:

  1. включить заголовочный файл#include<fstream>
  2. Создать объект потокаifstream ifs;
  3. Откройте файл и оцените, успешно ли он открыт ifs.open("文件路径,打开方式");.
  4. Чтение данных - четыре способа.
  5. Закройте файл ifs.close();.

Четыре способа:

  1. char buf[1024] = { 0 }; ifs >> buf, читать данные в файле в buf в виде символов и останавливаться, когда он встречает пробел или возврат каретки, а пробел или возврат каретки не будут прочитаны. Возвращает false, если был прочитан конец файла.
  2. char buf[1024] = { 0 };ifs.getline(buf, sizeof(buf),'\n'), sizeof(buf) указывает максимальную длину ожидаемых данных для чтения. Когда количество прочитанных байтов данных равно этому значению или прочитан конец файла, возвращается значение false; '\n' – это терминатор. это может быть указано При чтении Когда указанный символ извлекается, чтение останавливается на этот раз, и '\n' может указать, чтобы читать одну строку данных каждый раз. (Примечание: остановка чтения не возвращает false)
  3. string buf; getline(ifs, buf,'\n'), функция похожа на 2, но синтаксис другой, и stringнужно добавить заголовочный файл.
  4. 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;
}

рекомендация

отblog.csdn.net/qq_49030008/article/details/123439933