C++文件的操作及小实验示例代码详解

 更新时间:2022年05月26日 11:19:11   作者:白凤倚剑归  
这篇文章主要介绍了C++文件的操作及小实验,对于文件,它是一个流对象,对文件的操作无非是读和写,通过本文的学习大家将会理解文件的具体操作

对于文件,它是一个流对象,对文件的操作无非是读和写,我先来介绍一下写文件:

写文件:

写文件有五步:

1.包含头文件

#include"fstream"

2.创建流对象

ofstream ofs;

3.打开文件

ofs.open("文件路径",打开方式);

4.写数据

ofs<<"写入的数据";

5.关闭文件

ofs.close();

接下来再看看读文件:

读文件:

读文件有五步:

1.包含头文件

#include"fstream"

2.创建流对象

ifstream ifs;

3.打开文件

ofs.open("文件路径",打开方式);

4.写数据

四种读取方式

//第一种
char buf[1024] = { 0 };
while (ifs >> buf) {
    cout << buf << endl;
}

//第二种
char buf[1024] = { 0 };
while (ifs.getline(buf, sizeof(buf))) {
	cout << buf << endl;
}

//第三种
string buf;
while (getline(ifs, buf)) {
	cout << buf << endl;
}

//第四种
char c;
while ((c = ifs.get()) != EOF) {//EOF: end of file
	cout << c;
}

5.关闭文件

ifs.close();

*现在,走入正题——实验: *

实验介绍

实验目的:自定义三个text 型磁盘文件f1.txt、f2.txt 和f3.txt,并对它们进行指定的读写操作:先往f1.txt 以及f2.txt 中写出数据,之后再将它们读入而形成f3.txt 文件。  实验要求:通过使用运算符“>>”和“<<”,对自定义的text 型磁盘文件进行如下的指定操作。
(1) 对i=1,2,3,...,15,计算d=ii+0.5,并将15 个结果写出到自定义的text型磁盘文件f1.txt 中(注意,f1 文件中的数据从小到大有序);
(2) 对i=1,2,3,...,10,计算d=10i+0.5,并将10 个结果写出到自定义的text型磁盘文件f2.txt 中,而后再写出第11 个数:357.9(注意,f2 文件中的数据也从小到大有序);
(3) 读出文件f1.txt 以及f2.txt 中的数据,用来形成text 型磁盘文件f3.txt,但要求存放于f3.txt 中的数据仍然是有序的(按照从小到大的顺序);
(4) 从头到尾读出f3.txt 中的数据显示在屏幕上。

通过代码,大家将会理解文件的具体操作:

代码部分:

#include<fstream>//文件的头文件
using namespace std;
int main()
{
	double a1[15], a2[11], a3[26];//分别对应三个文本文件的数组
	//对f1的操作
	//先创建一个流对象
	ofstream ofs1;
	//打开文件
	ofs1.open("f1.txt", ios::out);
	//写数据
	for (int i = 0; i < 15; i++) {
		a1[i] = (i + 1) * (i + 1) + 0.5;
		ofs1 << a1[i] << " ";
	}
	//关闭文件
	ofs1.close();
	//对f2的操作
	//与上方的代码相似
	ofstream ofs2;
	ofs2.open("f2.txt", ios::out);
	for (int i = 0; i < 10; i++) {
		a2[i] = (i + 1) * 10 + 0.5;
		ofs2 << a2[i] << " ";
	}
	a2[10] = 357.9;
	ofs2 << a2[10] << " ";
	ofs2.close();
	//对f3的操作
	//与上方类似
	int i = 0, j = 0, k = 0;
	//比较大小
	while (i != 15 && j != 11) {
		if (a1[i] < a2[j])
			a3[k++] = a1[i++];
		else
			a3[k++] = a2[j++];
	}
	//将剩下未比较的数据存入
	while (i != 15)
		a3[k++] = a1[i++];
	while (j != 11)
		a3[k++] = a2[j++];
	ofstream ofs3;
	ofs3.open("f3.txt", ios::out);
	for (int i = 0; i < 26; i++)
		ofs3 << a3[i] << " ";
	ofs3.close();
	//接下来打f3并输出到屏幕上
	double f3[26];
	ifstream ifs3;
	ifs3.open("f3.txt", ios::in);
	for (int i = 0; i < 26; i++) {
		ifs3 >> f3[i];
		cout << f3[i] << " ";
	}
	ifs3.close();
}

查看文件操作:

1.右击箭头位置

2.点击“打开所在的文件夹”

3.此时就可以看到创建的txt

到此这篇关于C++文件的操作及小实验的文章就介绍到这了,更多相关C++文件的操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++动态规划中关于背包问题讲解

    C++动态规划中关于背包问题讲解

    可能有些读者有接触过动态规划,可能也有一些读者以前完全不知道动态规划这个东西,别担心,我这篇文章会为读者做一个入门,好让读者掌握这个重要的知识点
    2023-03-03
  • C语言实现电子时钟程序

    C语言实现电子时钟程序

    这篇文章主要为大家详细介绍了C语言实现电子时钟程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • c++ vector模拟实现代码

    c++ vector模拟实现代码

    vector是C++ STL中一个非常重要的容器,了解 vector 的底层实现原理,可以很好的帮助我们更加熟练的使用vector。这篇文章通过实例代码给大家介绍c++ vector模拟实现,感兴趣的朋友跟随小编一起看看吧
    2020-02-02
  • C语言详解函数与指针的使用

    C语言详解函数与指针的使用

    C语言这门课程在计算机的基础教学中一直占有比较重要的地位,然而要想突破C语言的学习,对函数和指针的掌握是非常重要的,本文将具体针对函数和指针的关系做详尽的介绍
    2022-04-04
  • C++中的最小生成树算法超详细教程

    C++中的最小生成树算法超详细教程

    这篇文章主要介绍了C++中的最小生成树算法超详细教程,最小生成树的最著名的算法有两个, 一个是Prim算法, 另一个当然就是Kruskal算法, 接下来, 我将尽我所能的介绍这两个算法, 也算是对自己学习的一个回顾吧,需要的朋友可以参考下
    2023-08-08
  • C++ 中CloseHandle 函数--关闭一个句柄

    C++ 中CloseHandle 函数--关闭一个句柄

    这篇文章主要介绍了C++ 中CloseHandle 函数--关闭一个句柄的相关资料,需要的朋友可以参考下
    2017-05-05
  • C++使用TinyXml实现读取XMl文件

    C++使用TinyXml实现读取XMl文件

    常见C/C++ XML解析器有Tinyxml、XERCES、squashxml、xmlite、pugxml、libxml等等,本文为大家介绍的是使用TinyXml实现读取XMl文件,需要的可以参考一下
    2023-06-06
  • C/C++的各种字符串函数你知道几个

    C/C++的各种字符串函数你知道几个

    这篇文章主要为大家详细介绍了C/C++的各种字符串函数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • Qt 仪表盘的实现示例

    Qt 仪表盘的实现示例

    仪表盘在很多汽车和物联网相关的系统中很常用,本文就来介绍一下Qt 仪表盘的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • C语言解决青蛙跳台阶问题(升级版)

    C语言解决青蛙跳台阶问题(升级版)

    所谓的青蛙跳台阶问题,就是指一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。本文将用C语言解决这一问题,需要的可以参考一下
    2022-01-01

最新评论