8.3 C++格式标识和操纵器
参考:http://www.weixueyuan.net/view/6409.html
总结:
我们需要借助格式标识符来控制cout对象的输出格式。
在ios_base类中,系统已经定义了很多格式标识符,通过这些标识符,我们可以很好地进行格式化控制,具体见下表。ios_base类中还定义有width和precision等函数。
除了能够直接调用这些格式标识符之外,我们可以借助类中提供的成员函数。
这些函数都是ios_base类的成员函数,可以通过对象直接调用,而cout是basic_ostream的一个对象,basic_ostream继承自ios_base,因此cout可以调用这些函数。
ios_base::showbase,即显示基数,基数的意思就是说在十六进制前加上0x,在八进制前加上0,十进制则不作处理。
一旦格式设置完成,则会一直保持格式,除非取消格式,因此在设置新格式前最好将原有设置的格式都取消。
这些格式化控制除了可以使用格式标识来控制外,我们还可以使用操纵器来控制。
操作器其本质是函数,它可以直接改变流的格式。
C++标准库中预定义了一些操纵器,使用其中带参数的操纵器则需要包含头文件iomanip,下标中列出了一些带参数的操纵器。
----------------------------------
在我们设计程序时,我们通常需要将输出数据以某种格式显示出来,例如我们希望将时间显示为“dd:dd:dd”的形式,如此一来我们就需要借助格式标识符来控制cout对象的输出格式。在ios_base类中,系统已经定义了很多格式标识符,通过这些标识符,我们可以很好地进行格式化控制,具体见下表。除此之外,ios_base类中还定义有width和precision等函数,这些函数同样可以辅助我们进行格式化控制。
| 格式标识符 | 用途 |
|---|---|
| boolalpha | 以true和false的形式读写bool类型变量 |
| dec | 以十进制的方式进行读写 |
| oct | 以八进制的方式进行读写 |
| hex | 以十六进制的方式进行读写 |
| internal | 放在正负号或基数标识之后 |
| left | 左对齐 |
| right | 右对齐 |
| fixed | 以定点方式表示浮点数 |
| scientific | 用科学计数法表示浮点数 |
| showbase | 输出时显示基数 |
| showpoint | 必须显示小数点 |
| showpos | 对非负数显示+号 |
| skipws | 忽略空格 |
| unitbuf | 写操作完成后清扫所有的缓冲区 |
| uppercase | 用大写字母表示十六进制 |
| adjustfield | 格式标识必须是left、right或internal |
| basefield | 格式标识必须是dec、oct或hex |
| floatfield | 格式标识必须是scientific或fixed |
有了表中所列标识符我们确实可以进行格式控制,但是除了能够直接调用这些格式标识符之外,我们可以借助类中提供的成员函数,具体成员函数见下表。
| 成员函数 | 用途 |
|---|---|
| flags() | 返回当前的格式标识 |
| flags( val ) | 将格式标识设置为val,并返回旧值 |
| setf ( val ) | 将val设置为当前的格式标识,并返回旧的格式标识 |
| setf ( val, ios_base::basefield ) | 将val设置为当前的格式标识,并返回旧的格式标识,且要求val为iso_base::dec、ios_base::hex或ios_base::oct三者之一 |
| setf ( val, ios_base::adjustfield ) | 将val设置为当前的格式标识,并返回旧的格式标识,且要求val为iso_base::left、ios_base::internal或ios_base::right三者之一 |
| setf ( ios_base::internal, ios_base::adjustfield ) | 在符号与数据之间填充字符,并返回旧标识 |
| setf ( ios_base::scientific, ios_base::floatfield ) |
设置科学计数法并返回旧标识 |
| setf ( ios_base::fixed, ios_base::floatfield ) |
设置定点计数法并返回旧标识 |
| setf ( 0, ios_base::floatfield ) | 设置默认浮点数表示法并返回旧标识 |
| unsetf ( val ) | 清楚指定的标识并返回旧标识 |
这些函数都是ios_base类的成员函数,可以通过对象直接调用,而cout是basic_ostream的一个对象,basic_ostream继承自ios_base,因此cout可以调用这些函数。
例1:
#include<iostream>
using namespace std; int main()
{
ios_base::fmtflags old_val = cout.flags( ios_base::left | ios_base::hex |ios_base::uppercase | ios_base::showbase ); for( int i = ; i < ; i ++ )
cout << i << endl;
cout<<endl<<endl;
cout.unsetf ( ios_base::left | ios_base::hex |ios_base::uppercase ); cout.setf ( old_val );
for( int i = ; i < ; i ++ )
cout << i << endl;
cout<<endl<<endl;
cout.unsetf( old_val ); cout.setf ( ios_base::hex | ios_base::uppercase );
cout << " hex " << << endl;
cout.unsetf( ios_base::hex | ios_base::uppercase );
cout.setf ( ios_base::oct );
cout << " oct " << << endl;
cout.unsetf( ios_base::oct );
cout.setf ( ios_base::dec );
cout << " dec " << << endl; return ;
}
本例中我们先调用flags函数设置输出格式,格式设置为左对齐和大写的十六进制,之后我们将100~149的数字全部输出,输出完之后我们将刚才设置的格式全部取消,然后重新设置为原始的格式old_val,再将数字100~149的数字重新输出一遍。之后我们演示的是将170按照十六进制、八进制和十进制的形式输出。
在整个程序中由于我们一开始设置了ios_base::showbase,即显示基数,基数的意思就是说在十六进制前加上0x,在八进制前加上0,十进制则不作处理。我们一开始设置了ios_base::showbase后,一直没有取消设置,因此在整个程序输出过程中一直都是加上了基数。出现这种情况也是我们要注意的,一旦格式设置完成,则会一直保持格式,除非取消格式,因此在设置新格式前最好将原有设置的格式都取消。
例2:
#include<iostream>
using namespace std; int main()
{
cout.width ( );
cout << - << endl; cout.setf( ios_base::left ,ios_base::adjustfield);
cout.width ( );
cout << - << endl;
cout.unsetf( ios_base::left ); cout.setf( ios_base::right ,ios_base::adjustfield);
cout.width ( );
cout << - << endl;
cout.unsetf( ios_base::right ); return ;
}
在本例中我们调用成员函数width控制输出的宽度为6个字符的位置,之后我们分别设置左对齐和右对齐,然后输出-100。从上面程序中我们可以看出默认是采用右对齐的方式输出的。
当然,这些格式化控制除了可以使用格式标识来控制外,我们还可以使用操纵器来控制,下面我们来简单了解一下操纵器。操作器其本质是函数,它可以直接改变流的格式。
例3:
cout << hex << uppercase << " hex " << << endl;
cout << oct << " oct " << << endl;
cout << dec << " dec " << << endl;
本例中hex、oct、dec和uppercase都是操纵器,它可以与输入或输出操作符一起使用。
C++标准库中预定义了一些操纵器,使用其中带参数的操纵器则需要包含头文件iomanip,下标中列出了一些带参数的操纵器。
| 格式标识符 | 作用对象 | 功能 |
|---|---|---|
| setbase( int n ) | basic_ostream | 将n设置为基数(默认值为0) |
| setfill( char_type c ) | basic_ostream | 设置填充字符为c |
| setprecision( int n ) | basic_ostream | 设置精度为n |
| setw( int n ) | basic_ostream | 设置域宽为n |
| setiosflags( val ) | ios_base | 设置指定的标识 |
| resetiosflags( val ) | ios_base | 清除指定的标识 |
表中列出的最后两个函数,其参数值为标识,即为格式标识符的组合。
8.3 C++格式标识和操纵器的更多相关文章
- Kafka的消息格式
Commit Log Kafka储存消息的文件被它叫做log,按照Kafka文档的说法是: Each partition is an ordered, immutable sequence of me ...
- Oracle Standard Error 列表
今天,我特意从网上找了一些,以及自己平时总结的,关于错误编号和说明,平时我们在写项目的时候,往往是可能会出现下面这些错误,例如:违反唯一约束,无效的会话ID,等等.希望对大家有点帮助!可以看看,如果有 ...
- SQL Server 多实例下的复制
一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 搭建步骤(Procedure) 注意事项(Attention) 二.背景(Contexts) ...
- ORA 各种oraclesql错误
ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...
- C#定义类型转化 及 格式化字符串
operator 关键字 operator 关键字用来重载内置运算符,或提供类/结构声明中的用户定义转换.它可以定义不同类型之间采用何种转化方式和转化的结果. operator用于定义类型转化时可采用 ...
- oracle 错误代码大全
oracle错误代码大全(超详细) ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最 ...
- Oracle存储过程中异常Exception的捕捉和处理
Oracle存储过程中异常的捕捉和处理 CREATE OR REPLACE Procedure Proc_error_process ( v_IN in Varchar2, v_OUT Out Var ...
- SQL错误码
///////////////////////////////////////////////////////////////ORA-00001: 违反唯一约束条件 (.)ORA-00017: 请求会 ...
- Oracle 存储过程异常处理
Oracle 存储过程异常处理 1.异常的优点 如果没有异常,在程序中,应当检查每个命令的成功还是失败,如 BEGIN SELECT ... -- check for ’no data f ...
随机推荐
- CRC分段校验
crc16 modbus分段校验码: const uint8_t ModbusCRCHighTab[] = { 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x ...
- SpringBoot集成TkMybatis插件
前提: 基于SpringBoot项目,正常集成Mybatis后,为了简化sql语句的编写,甚至达到无mapper.xml文件. 在本篇总结教程,不在进行SpringBoot集成Mybatis的概述. ...
- python3 语法小结
(1) 关键字 # -*- coding: utf-8 -*- #!/usr/bin/python3 """ 1.关键字(保留字) ['False', 'None', ' ...
- 雷林鹏分享:C# 基本语法
C# 基本语法 C# 是一种面向对象的编程语言.在面向对象的程序设计方法中,程序由各种相互交互的对象组成.相同种类的对象通常具有相同的类型,或者说,是在相同的 class 中. 例如,以 Rectan ...
- lncRNA表达定量方法评估
见文章:Benchmark of lncRNA Quantification for RNA-Seq of Cancer Samples Overall, 10-16% of lncRNAs can ...
- java---->Itellij idea报错:错误: 找不到或无法加载主类 main
没有设置好正确的类路径 点击上面圈红色处,在点击Edit Configuration,进入下面设置界面 切换到下面这个界面 红色×消失,运行正常,截图如下
- nginx开启fileinfo扩展
//实现网址 https://blog.csdn.net/m_nanle_xiaobudiu/article/details/80838424 (1) (2).make && make ...
- 数据结构与算法之PHP查找算法(二分查找)
二分查找又称折半查找,只对有序的数组有效. 优点是比较次数少,查找速度快,平均性能好,占用系统内存较少: 缺点是要求待查表为有序表,且插入删除困难. 因此,折半查找方法适用于不经常变动而查找频繁的有序 ...
- MapReduce--平均分,最高,低分以及及格率的计算
MapReduce--平均分,最高,低分以及及格率的计算 计算班级的平均分,以及个人的最高最低分,以及每个班级的及格率. 来先看一下我的数据. 时间 班级 姓名 科目 成绩 20180501 1708 ...
- Hadoop--之RPC开发
Hadoop--之RPC开发 介绍: 百度百科: RPC(Remote Procedure Call)—远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.R ...