【C++】文件IO流及stringstream流的使用

这篇具有很好参考价值的文章主要介绍了【C++】文件IO流及stringstream流的使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、引入

int main()
{
	string str;
	while (cin >> str)
	{
		cout << str << endl;
	}
	return 0;
}

【C++】文件IO流及stringstream流的使用

我们在OJ的时候经常会用到while(cin >> str),这里的流提取实际上是个阻塞操作,只要缓冲区还有数据就继续读,默认以空格或者换行结束,有空格说明是把两段字符串尾插到str。

那么它是怎么结束呢?
答案是输入[Ctrl]-c或者[Ctrl]-z + 换行

[Ctrl]-c是发送信号结束进程。
[Ctrl]-z + 换行是通过返回值条件判断结束while循环,具体看下面讲解。

二、自定义类型隐式类型转换

cin >> str的返回值是一个istream类
【C++】文件IO流及stringstream流的使用
实际上返回的就是cin对象。而c++98支持了隐式类型转换,把istream转换为bool,所以能够条件判断。

具体是怎么转换的呢?
看下面这个例子:

class A
{
public:
	A(int a)
		: _a(a)
	{}
private:
	int _a;
};

int main()
{
	// 内置类型转换成自定义类型
	A a = 1;
	return 0;
}

这里按道理来说是构造一个临时对象再拷贝构造,而编译器优化成了直接构造。如果没有单参数的构造函数就无法转换

那如果我们想要让自定义类型转换成内置类型呢?
直接int aa = a;肯定会报错。
但是我们可以加一个特殊的重载函数

class A
{
public:
	A(int a)
		: _a(a)
	{}

	operator int()
	{
		return _a;
	}
private:
	int _a;
};

int main()
{
	// 内置类型转换成自定义类型
	A a = 1;
	// 自定义类型转化成内置类型
	int aa = a;
	cout << aa << endl;
	return 0;
}

而我们上面说的把istream转化成bool类型就是类似这样实现的。
operator bool() 里面会检查是特殊字符([Ctrl]-z )就会返回false。

三、sync_with_stdio同步

我们知道cin和scanf都有自己的缓冲区,而如果我们用scanf写入再用cout输出,就会导致速度变慢很多(缓冲区拷贝)。

而sync_with_stdio函数是一个“是否兼容stdio”的开关,C++为了兼容C,保证程序在使用了std::printf和std::cout的时候不发生混乱,将输出流绑到了一起。

决定C++标准streams(cin,cout,cerr…)是否与相应的C标准程序库文件(stdin,stdout,stderr)同步,也就是是否使用相同的stream缓冲区,缺省情况是同步的,但由于同步会带来某些不必要的负担,因此该函数作用就是我们自己可以取消同步

#include <iostream>
int main() 
{
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);
    // IO
}

四、文件IO流

文件的读写有两种:
1️⃣ 二进制读写
2️⃣ 文本读写

【C++】文件IO流及stringstream流的使用
ofstream是写入文件,而ifstream是从文件中读取。

4.1 open和close文件

【C++】文件IO流及stringstream流的使用
【C++】文件IO流及stringstream流的使用
这里的参数表示我们想以什么样的方式打开文件。
比方说当我们想用二进制的方式打开文件:
ofs.open ("test.txt", std::ofstream::out | std::ofstream::binary)
而我们也可以在构造的时候直接传进参数。
【C++】文件IO流及stringstream流的使用
ofstream ofs("test.txt", std::ios_base::out | std::ios_base::binary)

4.2 写入文件与读出文件

struct ServerInfo
{
	char _address[32];
	int _port;
};


struct Config
{
public:
	Config(const char* filename)
		: _filename(filename)
	{}

	void Write(ServerInfo info)
	{
		ofstream ofs("test.txt", std::ios_base::out | std::ios_base::binary);
		ofs.write((char*)&info, sizeof info);
	}

	void Read(ServerInfo& info)
	{
		ifstream ifs("test.txt", std::ios_base::in | std::ios_base::binary);
		ifs.read((char*)&info, sizeof info);
	}
private:
	string _filename;
};

int main()
{
	Config con("text.txt");
	ServerInfo si = { "aaaaaa", 910 };
	con.Write(si);
	return 0;
}

【C++】文件IO流及stringstream流的使用

而我们也可以把数据读回来。

int main()
{
	Config con("text.txt");
	//ServerInfo si = { "aaaaaa", 910 };
	//con.Write(si);

	ServerInfo si;
	con.Read(si);
	cout << si._address << " " << si._port << endl;
	return 0;
}

【C++】文件IO流及stringstream流的使用
可以看到内存中和写出去显示出来的不一样。

当然我们可以用文本读写的方式。

struct ServerInfo
{
	char _address[32];
	int _port;
};


struct Config
{
public:
	Config(const char* filename)
		: _filename(filename)
	{}

	void Write(ServerInfo info)
	{
		ofstream ofs(_filename);
		// 重载
		ofs << info._address << endl;
		ofs << info._port << endl;
	}

	void Read(ServerInfo& info)
	{
		ifstream ifs(_filename);
		// 重载
		ifs >> info._address;
		ifs >> info._port;
	}
private:
	string _filename;
};

int main()
{
	Config con("text.txt");
	ServerInfo si = { "aaaaaa", 910 };
	con.Write(si);

	/*ServerInfo si;
	con.Read(si);
	cout << si._address << " " << si._port << endl;*/
	return 0;
}

【C++】文件IO流及stringstream流的使用

【C++】文件IO流及stringstream流的使用

五、stringstream流的使用

【C++】文件IO流及stringstream流的使用
在程序中如果想要使用stringstream,必须要包含头文件。在该头文件下,标准库三个类:
istringstream、ostringstream 和 stringstream,分别用来进行流的输入、输出和输入输出操作。

5.1 将数值类型数据格式化为字符串

int main()
{
	int a = 123;
	const char* b = "456";
	double c = 78.9;
	ostringstream os;
	os << a;
	os << b;
	os << c;
	cout << os.str() << endl;
	return 0;
}

【C++】文件IO流及stringstream流的使用
当然我们也可以把每个数据都提取出来。但此时输入的时候就要空格或者换行隔开。

int main()
{
	int a = 123;
	const char* b = "456";
	double c = 78.9;
	ostringstream os;
	os << a << " ";
	os << b << " ";
	os << c << " ";
	string ret = os.str();
	cout << ret << endl;
	int d;
	char e[20];
	double f;
	istringstream is(ret);
	is >> d >> e >> f;
	cout << d << " ";
	cout << e << " ";
	cout << e << " ";
	return 0;
}

【C++】文件IO流及stringstream流的使用

5.2 序列化和反序列化

序列化指的是将一个内存对象转化成一串字节数据(存储在一个字节数组中),可用于保存到本地文件或网络传输。反序列化就是将字节数据还原成内存对象。

总结

序列化:将对象变成字节流的形式传出去。
反序列化:从字节流恢复成原来的对象。

简单来说,对象序列化通经常使用于两个目的:
1️⃣ 将对象存储于硬盘上,便于以后反序列化使用;
2️⃣ 在网络上传送对象的字节序列

我们现在模拟一个聊天的发送窗口。

class Date
{
	friend ostream& operator << (ostream& out, const Date& d);
	friend istream& operator >> (istream& in, Date& d);
public:
	Date(int year = 1, int month = 1, int day = 1)
		:_year(year)
		, _month(month)
		, _day(day)
	{}
private:
	int _year;
	int _month;
	int _day;
};
istream& operator >> (istream& in, Date& d)
{
	in >> d._year >> d._month >> d._day;
	return in;
}
ostream& operator << (ostream& out, const Date& d)
{
	out << d._year << " " << d._month << " " << d._day;
	return out;
}


struct ServerInfo
{
	friend istream& operator >> (istream& in, ServerInfo& si);
	friend ostream& operator << (ostream& out, ServerInfo& si);
	string _name;// 昵称
	Date _d;// 时间
	string _msg;// 信息
};

istream& operator >> (istream& in, ServerInfo& si)
{
	in >> si._name  >> si._d >> si._msg;
	return in;
}

ostream& operator << (ostream& out, ServerInfo& si)
{
	out << si._name << " ";
	out << si._d << " ";
	out << si._msg << " ";
	return out;
}

int main()
{
	ServerInfo p{ "海阔天空", {2023, 4, 19}, "hello" };
	stringstream os;
	os << p;
	string ret = os.str();

	ServerInfo is;
	stringstream oss(ret);
	oss >> is;
	cout << "-------------------------------------------------------" << endl;
	cout << "昵称:" << is._name << " ";
	cout << is._d << endl;
	cout << is._name << ": " << is._msg << endl;
	cout << "-------------------------------------------------------" << endl;
	return 0;
}

【C++】文件IO流及stringstream流的使用文章来源地址https://www.toymoban.com/news/detail-427029.html



到了这里,关于【C++】文件IO流及stringstream流的使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • IO流——流的概述和分类

    1.IO流的分类 流的不同:输入流、输出流。 处理单位的不同:字节流、字符流。 流的角色不同:节点流、处理流。 2.基础IO流的框架 抽象基类 4个节点流(也称为文件流) InputStream FileInputStream OutputStream FileOutputStream Reader FileReader Writer FileWriter 3.FileReader FileWriter的使用 3.1执行

    2024年01月25日
    浏览(45)
  • p2 IO流原理及流的分类

    I/O是Input/Output的缩写,I/O技术是非常实用的技术,用于处理数据传输。如读/写文件,网络通讯等。 Java程序中,对于数据的输入/输出操作以”流(stream)“的方式进行。 java.io包下提供了各种”流“类和接口,用以获取不同种类的数据,并通过方法输入或输出数据。 输入in

    2024年02月07日
    浏览(26)
  • [Java]_[初级]_[使用SAX流的方式写入XML文件]

    文件的写入目前没有发现可以增量写入的,只能是完全重新写入。对于大量数据需要写入 XML 文件,还是和读 XML 文件一样,不需要生成 DOM 模型能节省不少的内存和指令。 在 java 标准库里,也是有相关的SAX类来写入数据流, StreamResult(OutputStream) 负责把数据写入输出流。 之后

    2024年02月10日
    浏览(44)
  • 使用FFmpeg将本地文件通过UDP推流的音视频

    推流是指将音视频数据通过网络传输到指定的目标端,而FFmpeg是一个功能强大的跨平台多媒体处理工具,可以用于音视频编解码、转码、处理等操作。本文将介绍如何使用FFmpeg将本地文件通过UDP协议进行推流,实现音视频数据的传输。 首先,需要确保已经安装了FFmpeg工具。如

    2024年03月19日
    浏览(50)
  • 一种使用wireshark快速分析抓包文件amr音频流的思路方法

    解决方案: 1. 使用wireshark过滤amr,并导出原始数据文件; 2.使用ue的二进制编辑模式,编辑该文件,添加amr头,6个字节数据“#!AMR”,字节数据为 23 21 41 4D 52 0A 3.修正格式:通过抓包发现,amr的负载中,总是多一个字节用于描述rtp流信息,这个字节被导出到了原始数据中,每一

    2024年02月06日
    浏览(33)
  • 由于对象流解析的数据与流的头部信息不匹配导致异常 java.io.StreamCorruptedException: invalid stream header: 7372001

    错误原因 先直接说错误原因 当使用对象流时,对象头和对象内容一起被写入输出流,而读取时也需要以相同的顺序读取对象头和对象内容 如果读取时的顺序与写入时的顺序不一致,或者在写入或读取对象头和对象内容之间更改了流的状态,则会出现 java.io.StreamCorruptedExcept

    2024年02月05日
    浏览(38)
  • 【C++】万字详解IO流(输入输出流+文件流+字符串流)

    流的概念:若干个字节组成的一个字节序列,代表信息从源到目的的流动 头文件 iostream 从标准输入读取流 cin //把空格、换行作为分隔符(不读空格) 从标准输出写入流 cout 首先,我们的这个分标题是插入符 , 这样一看大家是不是都懵了:cina,为什么不是 这个符号是插入符呢

    2024年02月04日
    浏览(42)
  • 【C++】string的使用

    🍿 从这里开始,便开始介绍 string 和 STL 容器的使用,以及相关容器的模拟实现,欢迎和博主一起学习。 目录 前言 引入   构造与赋值重载 构造 赋值重载 容量操作 容量查询 容量修改 清空判空 迭代器 正向迭代器 反向迭代器 const迭代器  成员访问 下标访问 边界访问 增删

    2024年02月03日
    浏览(30)
  • [C++]string的使用

    目录 string及其模拟实现::                 1.string类介绍                 2.string常用接口说明 string相关习题训练::                 1.仅仅反转字母                 2.找字符串中第一个只出现一次的字符                 3.字符串里面

    2024年02月03日
    浏览(29)
  • C++——string使用

    string() 构造空的srting类对象,空字符串 string(const char* str) 用字符串初始化 string(const string str) 拷贝构造,使用string类初始化 string(size_t n, char c)  用n个字符c初始化 size 返回字符串有效长度 capacity 返回总空间大小 empty 判断对象是否为空 clear 清空有效字符 reserve 为字符串预留空

    2024年02月10日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包