C++笔记1:操纵符输入输出

C++操纵符用来控制输出控制,一是输出的形式,二是控制补白的数量和位置。本文记录一下,在一些笔试的ACM模式可能有用。其中1-4节的部分是关于格式化输入输出操作,5-6节的部分是关于未格式化输入输出操作。

1. 控制布尔值的格式

一般我们用cout打印bool值为1或0,如果我们要打印为true或false,那么我们可以对流使用boolalpha操作符:

cout << "default bool values: " << true << " " << false
     << "\nalpha bool values: " << boolalpha
     << true << " " << false << endl;

输出的结果是:

default bool values: 1 0
alpha bool values: true false

操作符boolalpha会改变格式状态,会影响下一个和随后的输出,如果我们不想影响到后面的格式输出,我们需要使用另一个操纵符noboolalpha改变格式。

cout << "default bool values: " << true << " " << false
     << "\nalpha bool values: " << boolalpha
     << true << " " << false << endl
     << noboolalpha;

2. 控制整型的进制

我们常常需要将整型的进制转换为十六进制、八进制或十进制:

cout << "default: " << 20 << " " << 1024 << endl;
cout << "octal: " << oct << 20 << " " << 1024 << endl;
cout << "hex: " << hex << 20 << " " << 1024 << endl;
cout << "decimal: " << dec << 20 << " " << 1024 << endl;

输出的结果是:

default: 20 1024
octal: 24 2000
hex: 14 400
decimal: 20 1024

如果我们要在输出中指出进制:

  • 前导0x表示十六进制
  • 前导0表示八进制
  • 无前导字符串表示十进制

我们可以使用showbase修改上面的程序:

cout << showbase;//打印整型值显示进制
cout << "default: " << 20 << " " << 1024 << endl;
cout << "octal: " << oct << 20 << " " << 1024 << endl;
cout << "hex: " << hex << 20 << " " << 1024 << endl;
cout << "decimal: " << dec << 20 << " " << 1024 << endl;
cout << noshowbase;//恢复流状态

输出的结果:

default: 20 1024
octal: 024 02000
hex: 0x14 0x400
decimal: 20 1024

如果要显示整型数为大写的十六进制,我们可以使用uppercase:

cout << uppercase << showbase << hex // 打印整型值显示进制
     << "printed in hexadecimal: " << 20 << " " << 1024 << endl;
cout << nouppercase << noshowbase << dec << endl; // 恢复流状态

输出的结果:

printed in hexadecimal: 0X14 0X400

3. 控制浮点数格式

浮点数的格式主要有三种控制格式:

  • 以多高精度(多少个数字)打印浮点值
  • 数值是打印为十六进制、定点十进制还是科学计数法形式
  • 对于没有小数部分的浮点值是否打印小数点

默认情况下:

  • 浮点值按六位数字精度打印
  • 如果浮点值没有小数部分,则不打印小数点,根据浮点数的值选择打印成定点十进制或科学记数法形式
  • 非常大或非常小的数打印为科学计数法,其他值打印为定点十进制形式。

3.1 指定打印精度

可以式运算precision成员或使用setprecision操纵符来改变精度

  • precision成员是重载的。一个版本接受一个int值,将精度设置为此值,并返回旧精度值。另一个版本不接受参数,返回当前的精度值。
  • setprecision操纵符接受一个参数,用来设置精度。
#include <iostream>
#include <cmath>
#include <iomanip>
using namespace std;
int main()
{
    cout << "Precision: " << cout.precision()
         << ", Value: " << sqrt(2.0) << endl;
    cout.precision(12);
    cout << "Precision: " << cout.precision()
         << ", Value: " << sqrt(2.0) << endl;
    cout << setprecision(3);//要包含iomanip库
    cout << "Precision: " << cout.precision()
         << ", Value: " << sqrt(2.0) << endl;
}

输出的结果:

Precision: 6, Value: 1.41421
Precision: 12, Value: 1.41421356237
Precision: 3, Value: 1.41

下表是定义在iostream里的其他操纵符。
在这里插入图片描述

3.2 指定浮点数的记数法

除非要控制浮点数的表示形式,否则由标准库选择记数法是最好的方式。

我们可以强制一个流使用科学记数法、定点十进制或十六进制记数法。

  • 操纵符scientific改变流的状态用科学记数法。
  • 操纵符fixed改变流的状态使用定点十进制。

新标准库里我们可以使用hexfloat强制浮点数使用十六进制格式,另外还有一个defaultfloat的操纵符,将流恢复到默认状态,根据要打印的值选择记数法。

使用scientific、fixed或hexfloat精度控制的是小数点后面的数字位数,而默认情况下精度值指定的是数字的总位数,既包括小数点之后的数字也包括小数点之前的数字,我们可以使用fixed或scientific按列打印数值,因为小数点距小数部分的距离是固定的:

cout << "default format: " << 100 * sqrt(2.0) << '\n'
     << "scientific: " << scientific << 100 * sqrt(2.0) << '\n'
     << "fixed decimal: " << fixed << 100 * sqrt(2.0) << '\n'
     << "hexadecimal: " << hexfloat << 100 * sqrt(2.0) << '\n'
     << "use defaults: " << defaultfloat << 100 * sqrt(2.0) << '\n\n';

输出的结果:

default format: 141.421
scientific: 1.414214e+02
fixed decimal: 141.421356
hexadecimal: 0x8.d6bde009b35cp+4
use defaults: 141.4212570

3.3 打印小数点

默认情况下,当一个浮点数的小数部分为0时,不显示小数点,showpoint操纵符可以强制打印小数点:

cout << 10.0 << endl;
cout << showpoint << 10.0
     << noshowpoint << endl;

输出的结果:

10
10.0000

3.4 输出补白

当按列打印数据的时候,我们常常需要非常精细地控制数据格式,标准库提供了一些操纵符帮助我们完成所需的控制:

  • setw指定下一个数字或字符串值的最小空间,类似endl,不改变输出流的内部状态,它只决定下一个输出的大小。
  • left表示左对齐输出
  • right表示右对齐输出,右对齐是默认的格式
  • internal控制负数的符号的位置,它左对齐符号,右对齐值,用空格填满所有中间的空间
  • setfill允许一个字符代替默认的空格来补白输出
iomanip的操作符含义
setfill(ch)用ch填充空白
setprecision(ch)将浮点精度设置为n
setw(w)读或写值的宽度为w个字符
setbase(b)将整数输出为b进制
int i = -16;
double d = 3.14159;
//补白第一列,使用输出中最小12个为主
cout << "i: " << setw(12) << i << "next col" << '\n'
	<< "d: " << setw(12) << d << "next col" << '\n';
//补白第一列,左对齐所有列
cout << left 
	<< "i: " << setw(12) << i << "next col" << '\n'
	<< "d: " << setw(12) << d << "next col" << '\n'
	<< right; //恢复正常对齐
//补白第一列,右对齐所有列
cout << right
	<< "i: " << setw(12) << i << "next col" << '\n'
	<< "d: " << setw(12) << d << "next col" << '\n';
//补白第一列,但不在域的内部
cout << internal
	<< "i: " << setw(12) << i << "next col" << '\n'
	<< "d: " << setw(12) << d << "next col" << '\n';
//补白第一列,用#作为补白的字符
cout << setfill('#')
	<< "i: " << setw(12) << i << "next col" << '\n'
	<< "d: " << setw(12) << d << "next col" << '\n'
	<< setfill(' ');//恢复正常的补白字符

输出的结果:

i: -16next col
d: 3.14159next col
i: -16 next col
d: 3.14159 next col
i: -16next col
d: 3.14159next col
i: - 16next col
d: 3.14159next col
i: -#########16next col
d: #####3.14159next col

4. 控制输出格式

默认情况下,输入运算符会忽略空白符(空格符、制表符、换行符、换纸符和回车符)

char ch;
while (cin >> ch)
	cout << ch;

如输入

a  b         c

输出则为:

abc

操纵符noskipws会令运算符读取空白符,而不是跳过它们,为了恢复默认行为,使用skipws操纵符:

char ch;
cin >> noskipws;
while (cin >> ch)
	cout << ch;

如输入

a b   c

输出则为:

a b   c

5. 单字节操作

我们可以使用get和put来读取和写入一个字符

char ch;
while (cin.get(ch))
	cout.put(ch);

在这里插入图片描述

一般情况下,在读取下一个值之前,标准库保证我们可以退回最多一个值,即标准库保证在中间不进行读取操作的情况下能连续调用putback或unget。

函数peek和无参的get以int类型从输入流返回一个字符,它首先把要返回的字符先转换为unsigned char,然后将结果提升到int。这样返回的int确保是正值。标准库使用负值表示文件尾,这可以保证与任何合法字符的值都不同,头文件cstdio定义了一个名为EOF的const,可以检测从get返回的值是不是文件尾,而不用记忆文件尾的实际数值

int ch;
while ((ch = cin.get()) != EOF)
	cout.put(ch);

6. 多字节操作

有时我们需要使用IO操作一次处理大块的数据,如果我们需要自己分配并管理用来保存和提取数据的字符数组,这些操作容易出错,且有时速度也是我们需要考虑的,下表给出了多字节操作:

在这里插入图片描述
get和getline函数接受相同的参数,他们的行为类似但不相同,在两个函数中,sink都是一个charuuzu ,用来保存数据,两个函数都一直读取数据,直至下面条件之一发生:

  • 已读取的size-1字符
  • 遇到了文件尾
  • 遇到了分隔符
    两个函数的差别是处理分隔符的方式:get将分隔符留作istream中的下一个字符,而getline则读取并丢弃分隔符。无论哪个函数都不会将分隔符保存在sink中。常见的错误是本想从流里删除分隔符,但却忘了做。

一个常见的错误是将get或peek的返回值赋予一个char而不是一个int,如果在一台char被实现为unsigned char的机器上,下面的循环永远不会停止:

char ch;
while ((ch = cin.get()) != EOF)
	cout.put(ch);

当get返回EOF时会转换为一个unsigned char,转换得到的值和EOF的int不相等,循环不会停止。而如果char被实现为signed char的机器上,我们不能确定循环的行为。

参考

  1. 《C++ Primer》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/386723.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

uniapp API文档地址 以及 HBuilder安装

uniapp API文档地址 以及 HBuilder安装 一、进入 当前网站 uni-app 官网 [uni-app](https://zh.uniapp.dcloud.io/quickstart-hx.html)二、点击截图下载文件 三、 进入 当前网站 &#xff08;https://www.dcloud.io/hbuilderx.html&#xff09; 浏览器会识别 也可以自行选择…

基于GIS、RS、VORS模型、CCDM模型、geodetecto、GWR模型集成的生态系统健康的耦合协调分析

详情点击公众号&#xff1a;技术科研吧 链接&#xff1a;基于GIS、RS、VORS模型、CCDM模型、geodetecto、GWR模型集成的生态系统健康的耦合协调分析 前沿 当空间大数据、云计算与人工智能发生碰撞,地理服务产业也不断发生变革与进步。ArcGIS Pro 是一个专业的桌面 GIS 应用程…

17 外排序

排序分为内排序和外排序&#xff0c;内排序是在内存中的排序。外排序指在磁盘中文件的排序&#xff0c;因为在磁盘中&#xff0c;不能进行下标访问&#xff0c;归并排序经常用于磁盘中文件的排序 假如有10亿个整形数据在磁盘中&#xff0c;要对它排序&#xff0c;内存中只有1G…

水果FL Studio21.2最新中文版功能特点介绍

FL Studio 21的特点和优势包括&#xff1a; 丰富的主题换肤&#xff1a;用户可以通过调整色调、饱和度、亮度、文本、仪表和步进序列器的颜色&#xff0c;来个性化定制FL Studio 21的外观&#xff0c;使其更符合个人审美或工作风格。更快的音频编辑&#xff1a;FL Studio 21集…

AI少女/HS2甜心选择2 仿剑三剑灵人物卡全合集打包

AI少女/HS2甜心选择2 仿剑三剑灵人物卡全合集打包 内含&#xff1a;菩提禅音[剑网3]明教晓天喵姐[剑3]明教晓天喵姐无帽版[剑3]茱莉亚[剑灵] 下载地址&#xff1a; https://www.changyouzuhao.cn/12492.html

软件价值12-射箭游戏

射箭游戏&#xff0c;按空格键发射&#xff0c;打击移动靶&#xff0c;左上角显示成绩状态。 代码&#xff1a; import pygame import sys import random# 初始化Pygame pygame.init()# 设置窗口大小 SCREEN_WIDTH 800 SCREEN_HEIGHT 600 screen pygame.display.set_mode((…

【开源】基于JAVA+Vue+SpringBoot的就医保险管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 科室档案模块2.2 医生档案模块2.3 预约挂号模块2.4 我的挂号模块 三、系统展示四、核心代码4.1 用户查询全部医生4.2 新增医生4.3 查询科室4.4 新增号源4.5 预约号源 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVue…

DS:树及二叉树的相关概念

创作不易&#xff0c;兄弟们来波三连吧&#xff01;&#xff01; 一、树的概念及结构 1.1 树的概念 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树&#xff0c…

利用Cloudflare Workers实现网页状态监控

首先 Fork cf-workers-status-page 浏览器地址栏输入 https://deploy.workers.cloudflare.com/?urlhttps://github.com/$YourUserName/cf-workers-status-page 获取 Cloudflare 账户内的 Account ID 和 API Token 授权的 token 需要 workes 的编辑权限 在 Github actio…

LeetCode二叉树的垂序遍历

题目描述 给你二叉树的根结点 root &#xff0c;请你设计算法计算二叉树的 垂序遍历 序列。 对位于 (row, col) 的每个结点而言&#xff0c;其左右子结点分别位于 (row 1, col - 1) 和 (row 1, col 1) 。树的根结点位于 (0, 0) 。 二叉树的 垂序遍历 从最左边的列开始直到…

DolphinScheduler安装与配置

DolphinScheduler概述 Apache DolphinScheduler是一个分布式、易扩展的可视化DAG工作流任务调度平台。致力于解决数据处理流程中错综复杂的依赖关系&#xff0c;使调度系统在数据处理流程中开箱即用。 DolphinScheduler的主要角色如下&#xff1a; MasterServer采用分布式无…

CPython:表达式的求值顺序(evaluation order)

相关阅读 Pythonhttps://blog.csdn.net/weixin_45791458/category_12403403.html?spm1001.2014.3001.5482 C中表达式的求值 C语言针对表达式的计算&#xff0c;设置了操作符的优先级和结合性这两个特性&#xff0c;优先级用于解析不同优先级的符号&#xff0c;结合性用于解析…

【基础】第K大与第K小数

说明 给定一个长度为N(0< n< 10000)的序列&#xff0c;保证每一个序列中的数字a[i]是正整数 &#xff0c;编程要求求出整个序列中第k大的数字减去第k小的数字的值m&#xff0c;并判断m是否为质数。(0< k< n) 输入数据 第一行为2个数n&#xff0c;k&#xff08;…

【北邮鲁鹏老师计算机视觉课程笔记】10 Classification 分类

【北邮鲁鹏老师计算机视觉课程笔记】10 Classification 分类 1 图像识别的基本范式 检测问题&#xff1a;不仅要知道有没有&#xff0c;还要知道在哪里 分类是整图级标签&#xff0c;检测是区域级标签&#xff0c;分割是像素级标签 2 检测任务的应用 3 单实例识别与类别识别…

《Linux 简易速速上手小册》第3章: 文件系统与权限(2024 最新版)

文章目录 3.1 Linux 文件系统结构3.1.1 重点基础知识3.1.2 重点案例&#xff1a;设置一个 Web 服务器3.1.3 拓展案例 1&#xff1a;日志文件分析3.1.3 拓展案例 2&#xff1a;备份用户数据 3.2 理解文件权限3.2.1 重点基础知识3.2.2 重点案例&#xff1a;共享项目文件夹3.2.3 拓…

java学习08---面向对象

一 类和对象 1 类和对象的理解 客观存在的事物皆为对象 &#xff0c;所以我们也常常说万物皆对象。 类 简单理解&#xff1a;类就是对现实事物的一种描述 类是对象的数据类型&#xff0c;类是具有相同属性和行为的一组对象的集合 类是对现实生活中一类具有共同属性和行为的事…

Python教程56:海龟画图turtle画kitty猫

---------------turtle源码集合--------------- Python教程91&#xff1a;关于海龟画图&#xff0c;Turtle模块需要学习的知识点 Python教程51&#xff1a;海龟画图turtle画&#xff08;三角形、正方形、五边形、六边形、圆、同心圆、边切圆&#xff0c;五角星&#xff0c;椭…

【python量化交易】qteasy使用教程02 - 获取和管理金融数据

qteasy教程2 - 获取并管理金融数据 qteasy教程2 - 获取并管理金融数据开始前的准备工作获取基础数据以及价格数据下载交易日历和基础数据查看股票和指数的基础数据下载沪市股票数据从本地获取股价数据生成K线图 数据类型的查找定期下载数据到本地回顾总结 qteasy教程2 - 获取并…

【Web】CVE-2021-31805 s2-062漏洞复现学习

目录 Struts2介绍 漏洞概况 OGNL与Struts2 简单原理 漏洞复现 正向rce 反弹shell payload分析 Struts2介绍 Struts 2 是一个流行的用于构建 Java Web 应用程序的开源 Web 应用程序框架。它是 Apache 软件基金会下的一个顶级项目&#xff0c;是 Struts 框架的升级版本。…

docker磁盘不足!已解决~

目录 &#x1f35f;1.查看docker镜像目录 &#x1f9c2;2.停止docker服务 &#x1f953;3.创建新的目录 &#x1f32d;4.迁移目录 &#x1f37f;5.编辑迁移的目录 &#x1f95e;6.重新加载docker &#x1f354;7.检擦docker新目录 &#x1f373;8.删掉旧目录 1.查看doc…