深入理解 C++ 中的 IO 流【iostream篇】

2024-03-26 23:20
文章标签 c++ 深入 理解 io iostream

本文主要是介绍深入理解 C++ 中的 IO 流【iostream篇】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++ 中的输入输出流(iostream)是非常重要的一部分,它们提供了与用户交互以及与文件系统进行数据交换的功能。本文将深入探讨 C++ 中的 cin 和 cout,介绍它们的使用方法、缓冲区以及常用的成员函数等相关知识。

1. cin 和 cout 的基本使用

在 C++ 中,cin 和 cout 是标准输入输出流对象,分别用于从标准输入(通常是键盘)读取数据和向标准输出(通常是屏幕)写入数据。

#include <iostream>int main() {int num;std::cin >> num;std::cout << num << std::endl;return 0;
}

在上面的示例中,我们使用 cout 来打印提示消息,并使用 cin 读取用户输入的数字。

2. 运算符重载与 iostream

在 iostream 中,常见的运算符重载包括插入运算符 << 和提取运算符 >>。这两个运算符分别用于输出数据到流和从流中提取数据。

重载插入运算符 <<

插入运算符 << 用于将数据插入到输出流中,通常用于输出数据到控制台或文件。

#include <iostream>class MyClass {
public:int data;MyClass(int d) : data(d) {}friend std::ostream& operator<<(std::ostream& os, const MyClass& obj) {os << obj.data;return os;}
};int main() {MyClass obj(10);std::cout  << obj << std::endl;return 0;
}

在上面的示例中,我们重载了 << 运算符,使得 MyClass 类型的对象可以直接通过 cout 输出。

重载提取运算符 >>

提取运算符 >> 用于从输入流中提取数据,通常用于从控制台或文件中读取数据。

#include <iostream>class MyClass {
public:int data;MyClass() {}friend std::istream& operator>>(std::istream& is, MyClass& obj) {is >> obj.data;return is;}
};int main() {MyClass obj;std::cin >> obj;std::cout << obj.data << std::endl;return 0;
}

在上面的示例中,我们重载了 >> 运算符,使得可以直接从 cin 输入到 MyClass 类型的对象。并且由于fstream和sstream继承了iostream,因此重载了iostream后fstream和sstream也可以使用,后面的博客会将。

3. cin 和 cout 的缓冲区

在默认情况下,cin 和 cout 都是带有缓冲区的。这意味着输入的数据不会立即被程序处理,而是暂时存储在缓冲区中,直到程序需要时才进行读取或写入操作。

缓冲区刷新

缓冲区的刷新通常由以下情况触发:

  • 缓冲区已满:当缓冲区填满数据时,会自动刷新缓冲区,将数据发送给目标设备(如屏幕)。
  • 手动刷新:可以使用 std::flush 强制刷新输出缓冲区。
std::cout << "Flushing buffer" << std::flush;

关闭缓冲区

有时候,我们可能需要关闭缓冲区以实时地输出数据,而不需要等到缓冲区满或程序结束时才输出。可以使用 std::ios::sync_with_stdio(false) 来关闭 cin 和 cout 的缓冲区。

#include <iostream>int main() {std::ios::sync_with_stdio(false); // 关闭缓冲区std::cout << "This will be printed immediately" << std::endl;return 0;
}

4. cin 和 cout 的常用成员函数

cin 和 cout 提供了许多有用的成员函数,可以帮助我们更灵活地处理输入输出操作。

cin 成员函数

  • cin.get(): 从输入流中获取下一个字符。
  • cin.getline(char*, int): 从输入流中获取一行数据。可指定分割符,默认为'\n'。
  • cin.read(char*, int):从输入流中读取一定数量的字符

cout 成员函数

  • cout.put(char): 向输出流中写入一个字符。
  • cout.write(char*, int): 向输出流中写入一定数量的字符。

具体使用和例子可以查看手册。

这篇关于深入理解 C++ 中的 IO 流【iostream篇】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/850200

相关文章

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)