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的机器上,我们不能确定循环的行为。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言—基础数据类型(含进制转换)

进制转换不多&#xff0c;但我觉得适合小白(我爱夸自己嘿嘿) 练习 1. 确认基础类型所占用的内存空间(提示&#xff1a;使用sizeof 运算符)&#xff1a; 在这里我说一下&#xff0c;long 类型通常占用 4 字节。在 64 位系统上&#xff0c;long 类型通常也可为 8 字节。 格式…

LeetCode、208. 实现 Trie (前缀树)【中等,自定义数据结构】

文章目录 前言LeetCode、208. 实现 Trie (前缀树)【中等&#xff0c;自定义数据结构】题目链接与分类思路 资料获取 前言 博主介绍&#xff1a;✌目前全网粉丝2W&#xff0c;csdn博客专家、Java领域优质创作者&#xff0c;博客之星、阿里云平台优质作者、专注于Java后端技术领…

【ASP.NET Core 基础知识】--测试--单元测试和集成测试

一、单元测试 1.1 单元测试概述 单元测试是软件开发中的一种测试方法&#xff0c;用于验证软件中的最小可测试单元——通常是函数、方法或类——的行为是否符合预期。它的核心思想是将程序分解成独立的单元&#xff0c;并针对每个单元编写测试用例&#xff0c;以验证其功能是…

假期day9(2024/2/14)

获取数据库查询的值并调用值使用函数&#xff1a;sqlite3_get_table 在回调函数中获取数据库查询值&#xff0c;无法在其他函数调用&#xff1a;使用函数sqlite3_exec(db, sql, select_callback, &flag, &errmsg&#xff09; 创建表 create table if not exists 表名…

力扣代码学习日记一

Problem: 389. 找不同 文章目录 思路解题方法复杂度Code 思路 给定两个字符串 s 和 t &#xff0c;它们只包含小写字母。 字符串 t 由字符串 s 随机重排&#xff0c;然后在随机位置添加一个字母。 请找出在 t 中被添加的字母。 示例 1&#xff1a; 输入&#xff1a;s "a…

c++ 自定义Logger 日志类

Logger 日志类 线程安全的日志组件 默认保存到文件&#xff0c;并支持回调函数&#xff0c;比如显示到界面 #ifndef LOGGER_H #define LOGGER_H#include <iostream> #include <sstream> #include <mutex> #include <thread> #include <iomanip&g…

低资源学习与知识图谱:构建与应用

目录 前言1 低资源学习方法1.1 数据增强1.2 特征增强1.3 模型增强 2 低资源知识图谱构建与推理2.1 元关系学习2.2 对抗学习2.3 零样本关系抽取2.4 零样本学习与迁移学习2.5 零样本学习与辅助信息 3 基于知识图谱的低资源学习应用3.1 零样本图像分类3.2 知识增强的零样本学习3.3…

云原生介绍与容器的基本概念

云原生介绍 1、云原生的定义 云原生为用户指定了一条低心智负担的、敏捷的、能够以可扩展、可复制的方式最大化地利用云的能力、发挥云的价值的最佳路径。 2、云原生思想两个理论 第一个理论基础是&#xff1a;不可变基础设施。 第二个理论基础是&#xff1a;云应用编排理…

备战蓝桥杯---图论基础理论

图的存储&#xff1a; 1.邻接矩阵&#xff1a; 我们用map[i][j]表示i--->j的边权 2.用vector数组&#xff08;在搜索专题的游戏一题中应用过&#xff09; 3.用邻接表&#xff1a; 下面是用链表实现的基本功能的代码&#xff1a; #include<bits/stdc.h> using nam…

纪念一下 开始写博客两周以来第一次入围榜单

两周里 创作博客 第一次进入热榜 虽然只有几十名 但也算是一个突破 确实没想到自己随便做的笔记就入围了 感谢各位大佬的支持&#xff01;继续进步&#xff01;&#x1f973;&#x1f973;&#x1f973;

ubuntu下conda如何设置镜像源(清华镜像源)

ubuntu下如何设置镜像源 首先贴出.condarc&#xff0c;直接给出清华的镜像源&#xff0c;需要的小伙伴直接使用&#xff0c;别看内容了 # ~/.condarc channels:- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/r- https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs…

服务流控(Sentinel)

引入依赖 <!-- 必须的 --> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId> </dependency><!-- sentinel 核心库 --> <dependency><groupId>com.ali…

权限系统设计

权限系统设计 RBAC 基于角色的访问控制 ABAC 基于属性的访问控制 普通的系统无非 CRUD&#xff0c;那系统如何控制一个用户该看到哪些数据、能操作哪些功能&#xff1f;日常开发中最常用到 RBAC 和 OAuth2 这两种访问控制和授权方案 RBAC 基于角色的访问控制 所有的访问控制模…

GoZero 微服务个人探究之路(十一)编写sql语句所用到的sqlx包

前言 使用go-zero的脚手架工具goctl生成数据库代码时候&#xff0c;我们发现goctl引入了sqlx这个包来进行sql操作&#xff0c;本文旨在对sqlx包进行整理&#xff0c;来方便我们使用go-zero&#xff0c;sqlx进行sql操作 Why sqlx 为什么要额外引入sqlx包&#xff0c;增加复杂…

力扣精选算法100道——【模板】前缀和 (二维)

目录 &#x1f388;题目解析 &#x1f388;算法原理 &#x1f388;实现代码 二维前缀和【模板】 &#x1f388;题目解析 上一题我们讲述了一维的前缀和求法。 第一行三个参数&#xff0c;n是行数3&#xff0c;m是列数4&#xff0c;q3代表查询次数 接下来就是n行m列的矩阵…

基于python混沌系统敏感文本信息加密算法的研究与实现,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝30W、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

【Python】洛谷P7614 [COCI2011-2012#2] NAJBOLJIH 5

P7614 [COCI2011-2012#2] NAJBOLJIH 5 题目描述 给定 8 8 8 个数字 X 1 , X 2 , . . . , X 8 X_1,X_2,...,X_8 X1​,X2​,...,X8​&#xff0c;从中选出 5 5 5 个数字&#xff0c;使得这 5 5 5 个数字的总和最大。输出这 5 5 5 个数字的和以及它们的编号。 X i X_i Xi​…

微服务OAuth 2.1认证授权Demo方案(Spring Security 6)

文章目录 一、介绍二、auth微服务代码1. SecurityConfig2. UserDetailsService3. 总结 三、gateway微服务代码1. 统一处理CORS问题 四、content微服务代码1. controller2. SecurityConfig3. 解析JWT Utils4. 总结 五、一些坑 书接上文 微服务OAuth 2.1认证授权可行性方案(Sprin…

【51单片机】串口(江科大)

8.1串口通信 1.串口介绍 2.硬件电路 3.电平标准 电平标准是数据1和数据0的表达方式,是传输线缆中人为规定的电压与数据的对应关系,串口常用的电平标准有如下三种: 电平标准是数据1和数据O的表达方式,是传输线缆中人为规定的电 压与数据的对应关系,串口常用的电平标准有如下…

【QT+QGIS跨平台编译】之三十六:【RasterLite2+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

文章目录 一、RasterLite2介绍二、文件下载三、文件分析四、pro文件五、编译实践一、RasterLite2介绍 RasterLite2是一个开源的轻量级栅格数据库,可以用于存储和管理各种类型的栅格数据,包括卫星遥感图像、数字高程模型等。 与传统的GIS数据存储方式不同,RasterLite2采用基…