C++标准库笔记:13.7 格式化

2023-10-24 10:08
文章标签 c++ 笔记 格式化 标准 13.7

本文主要是介绍C++标准库笔记:13.7 格式化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

格式标志

格式标志可以控制输入输出的格式,比如是否在正数前加+号,用八进制、十进制、十六进制来显示数据等。

以下是访问格式标志的成员函数(定义在ios_base类中)

成员函数意义
setf(flags)增加标志,返回修改前的所有标志
setf(flags, mask)增加标志,mask参数存放的标志则被清除,返回修改前的所有标志
unsetf(flags)清除标志
flags()返回当前所有标志
flags(flags)将flags设为新的格式标志,返回修改前的所有标志
copyfmt(stream)从stream中复制所有格式定义

说明:
setf(flags, mask)举例: std::cout.sef( std::ios::hex, std::ios::basefield);
其中标志位ios::basefield是hex|oct|dec三个标志的组合,其它标志位定义参考如下,

static const _Fmtflags skipws = (_Fmtflags)_IOSskipws;
static const _Fmtflags unitbuf = (_Fmtflags)_IOSunitbuf;
static const _Fmtflags uppercase = (_Fmtflags)_IOSuppercase;
static const _Fmtflags showbase = (_Fmtflags)_IOSshowbase;
static const _Fmtflags showpoint = (_Fmtflags)_IOSshowpoint;
static const _Fmtflags showpos = (_Fmtflags)_IOSshowpos;
static const _Fmtflags left = (_Fmtflags)_IOSleft;
static const _Fmtflags right = (_Fmtflags)_IOSright;
static const _Fmtflags internal = (_Fmtflags)_IOSinternal;
static const _Fmtflags dec = (_Fmtflags)_IOSdec;
static const _Fmtflags oct = (_Fmtflags)_IOSoct;
static const _Fmtflags hex = (_Fmtflags)_IOShex;
static const _Fmtflags scientific = (_Fmtflags)_IOSscientific;
static const _Fmtflags fixed = (_Fmtflags)_IOSfixed;
static const _Fmtflags boolalpha = (_Fmtflags)_IOSboolalpha;
static const _Fmtflags _Stdio = (_Fmtflags)_IOS_Stdio;
static const _Fmtflags adjustfield = (_Fmtflags)(_IOSleft| _IOSright | _IOSinternal);
static const _Fmtflags basefield = (_Fmtflags)(_IOSdec| _IOSoct | _IOShex);
static const _Fmtflags floatfield = (_Fmtflags)(_IOSscientific| _IOSfixed);

为了与IO操作符<<、>>配合使用,实现了以下两个操控器(带参数)来设置格式标志

操控器意义
std::setiosflags(flags)将flags设为格式标志(调用setf(flags) )
std::resetiosflags(mask)清除mask所标识的一组标志(调用setf(0, mask) )

例如:
cout << std::resetiosflags( ios::basefield ) << std::setiosflags( ios::hex ) << 15 << endl;
输出:
f

布尔值 的IO格式

由标志boolalpha来控制,若设置了此标志,便以文字表示,否则又数据表示,缺省的未被设立。注:此标志被设立,就一直生效,除非清除此标志

为了与操作符<<、>>配合使用,实现了以下操控器

操控器意义
std::boolalpha设立标志ios::boolalpha
std::noboolalpha清除标志ios::boolalpha

例如以下

cout << std::boolalpha << true << endl;
cout << false << endl;

输出的为:
true
false

字段宽度、填充字符、位置对齐

字段宽度、填充字符由成员函数控制,位置对齐方式则由格式标志来控制。

成员函数意义
width()返回当前字符宽度
width(val)设置当前字符宽度,并返回先前的字符宽度
fill()返回当前填充字符
fill(c)设置当前填充字符,并返回先前填充字符

以上表格中,函数width调用后的作用为一次性的,即执行了任意格式化IO操作后,就会恢复width的值为缺省状态。而fill设置的则一直生效,除非重新设置。例如:

//以^符号填充
cout.fill( '^' );cout.width( 4 );
cout << 1 << endl;//恢复默认width
cout << 1 << endl;

位置对齐格式标志如下:

掩码标志意义
ios::adjustfieldios::left左对齐
ios::right右对齐
ios::internal符号靠左对齐,数值靠右对齐
None右对齐(默认)

同样,也提供了对应的操控器

  • std::setw(val),相当于widht(val)
  • std::setfill(c),相当于fill(c)
  • std::left,相当于setf( ios::left, ios::adjustfield)
  • std::right,相当于setf(ios::left, ios::adjustfield)
  • std::internal,相当于setf(ios::internal, ios::adjustfield)
  • -

正号、大写字符

由格式标志: ios::showpos、ios::uppercase来控制。ios::showpos被设置了,则在正数前显示+号,ios::uppercase标志被设置了,则针对十六进制、科学记号等的字母就以大写的格式输出,对字符串是不会有影响的。

同样,也提供了对应的操控器

  • std::showpos
  • std::noshowpos
  • std::uppercase
  • std::nouppercase

注:此两个标志被设立,就一直生效,除非清除此标志

数值进制

由格式标志控制

  • ios::oct,以八进制进行读写
  • ios::dec,以十进制进行读写
  • ios::hex,以十六进制进行读写
  • none,以十进制输出;读取时则视起始字符而定
  • ios::showbase, 若被设置,则显示数字的进制,八进制以0开头,十六进制则以0x开头

同样的,也有相应的操作器

  • std::oct
  • std::dec
  • std::hex
  • std::showbase
  • std::noshowbase

注:此四个标志被设立,就一直生效,除非清除此标志

浮点数表示法

浮点数表示由格式标志控制

  • ios::fixed,使用小数表示法
  • ios::scientific,使用科学计数表示法
  • None,使用上述两者中最适合者(默认)
  • ios::showpoint,总是书写小数点

精度控制成员函数

  • precision(),返回当前浮点数精度
  • precision(val),设置浮点数精度

对应操控器

  • std::showpoint
  • std::noshowpoint
  • std::setprecision(val)
  • std::fixed
  • std::scientific

注:以上标志被设立,就一直生效,除非清除此标志,精度被设置,也一样

一般性格式定义

格式标志

  • ios::skipws,调用>>读取数值时,跳过起始空格,默认设置此标志
  • ios::unitbuf,每次输出后,清空output缓冲区

操控器

  • std::skipws
  • std::noskipws
  • unitbuf
  • nounitbuf

注:以上标志被设立,就一直生效,除非清除此标志

国际化

ios_base类定义了数个成员函数来支持国际化

  • imbue(loc),设置locale对象
  • getloc(),返回当前locale对象
  • widen(c),将char型别c转换成stream字符集中的
  • narrow(c, def),widen的逆操作

总结

  • 格式标志ios::width是一次性的 ,即执行了任意格式化IO操作后,就会恢复width的值为缺省状态
  • std::ws,这个操控器也是一次性的,文章http://blog.csdn.net/s634772208/article/details/72852975介绍了此操控器
  • 注意std::skipwsstd::ws的区别,前者是表示调用>>时,跳过起始空格,后者读取时忽略空格,并且是一次性的。

以下演示std::noskipws的用法:

//此处若输入(_表空格):_1space
//则啥也不输出,因为>>读取字符串时是以空格来判断是否结束的
//第一个空格没被跳过,表示结束读取,因为啥也没读到,流被设置读取失败
std::string strTemp;
std::cin >> std::noskipws;
while( cin >> strTemp )
{cout << strTemp << endl;
}
//此处会一个字符一个字符的读取,空格也会被读取
//若输入: _a_b
//则输出:
//_
//a
//_
//b
char c;
cin >> std::noskipws;
while( cin >> c )
{if ( c == '\n'){continue;}cout << c << endl;
}

这篇关于C++标准库笔记:13.7 格式化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【C++ Primer Plus习题】13.4

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

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提供个模板形参的名

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

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)

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现