/*

设置输出字符的宽度
width(int)是iostream类的成员函数,可以通过cout对象来调用,即cout.width(int)
注:

1.width(int)只影响将要显示的一个对象,之后字段宽度会自动恢复为默认值
2.如果设定的字段宽度小于要输出的字符的宽度,则字符全部输出
3.如果设定的字段宽度大于要输出的字符的宽度,则字符右对齐输出,多余部分用空格填充

设置填充字段
cout.fill(char)可以设置填充字段
注:fill(char)会一直生效,直至重新设置

设置浮点数的显示精度
cout.precision(int)可以设置浮点数的显示精度(不包括小数点)
注:

1.如果设置的精度大于浮点数的位数,如果浮点数能根据IEEE754精确表示,则补零;如果浮点数不能精确表示,则尽量接近
2.如果设置的精度小于浮点数的位数,采用科学计数法表示

3.precision(int)单独使用,表示设置有效位数;与fixed或者scientific连用,表示设置小数位的精度
4.precision(int)会一直生效

setf()函数

setf()函数原型如下:
fmtflags setf(fmtflags)
fmtflags setf(fmtflags,fmtflags)
先看第一个原型。
其中fmtflags是一种标志类型,或者说标志位。
ios_base类的保护数据成员是一个15位的二进制数字,或者说是15个标志位,这15个标志位与ios类的15个枚举型常量一一对应,对应关系如下:
boolalpha    fixed    scientific    hex    oct    dec    internal    right    left    showpos    showpoint    showbase
0         0      0        0     0     1        0         0      0     0            0         0 
uppercase   unitbuf   skipws
0         0      1
即ios类的15个枚举型常量与ios_base类的15位二进制数字000 0010 0000 0001一一对应。另外,可以看到,二进制数字的15位除了skipws和dec对应的位数默认为1之外,其他均默认为0 (注:上表是VC++的对应关系)
15个标志的含义如下所示:
ios::boolalpha    bool型数值的输入和输出使用文本形式(即true或false)
ios::fixed        定点格式输出,即以小数点的形式表示浮点数
ios::scientific      用科学记数法表示浮点数
ios::hex          采用十六进制
ios::oct          采用八进制
ios::dec         采用十进制
ios::internal        输出格式为居中对齐
ios::right             输出格式为右对齐
ios::left          输出格式为左对齐
ios::showpos        在正数前面加上+号
ios::showpoint     显示末尾的0和小数点
ios::showbase      显示进制,即在十六进制数前添加0x,在八进制数前添加0
ios::uppercase     大写显示
ios::unitbuf     每次执行输出操作后均会清空缓冲区
ios::skipws      忽略输入流中的空白字符,即当我们输入的字符前面有空格时,存储的时候会自动忽略
注:
1.设置多个标志位用"|"隔开
2.默认对齐方式为右对齐
3.setf(ios::showpoint)与precision连用时,会输出小数点(单独的precision不会输出小数点)
4.ios::internal输出格式为居中对齐,其中符号左对齐,值右对齐;如果是十六进制,则前缀0x左对齐
5.ios::uppercase只对十六进制起作用,即将0x变为0X
6.ios::fixed或ios::scientific与ios::presicion连用表示的是小数位数,而不是有效位数
7.以上15个枚举型常量称之为标准控制符

下面看setf()的第二种原型,即:
fmtflags setf(fmtflags,fmtflags)
其中第一个参数是要开启的标志位,第二个参数是要清除的标志位,标志位的清除通过指示标志位来实现
指示标志位共有三个,如下:
ios::basefield 指示相关标志位:dec、oct、hex
ios::adjustfield 指示相关标志位:left、right、internal
ios::floatfield 指示相关标志位:fixed、scientific
其实现原理是15个标志位中只有要清除的标志位为1,其余位为0,然后取反后与15个标志位进行与操作
另外,指示标志位也是ios类从ios_base类中继承而来,因此ios::adjustfield等效于ios_base::adjustfield
注:清除多个标志位用"|"隔开

清除标志位
unsetf()函数可以实现标志位的清除

注:unsetf()实现原理同指示标志位是一样的,都是15个标志位中只有要清除的标志位为1,其余位为0,然后取反后与15个标志位进行与操作

*/

#include <iostream>
using namespace std;
int main()
{
const float number=-185.12f;
cout.width();
cout.setf(ios::left);
cout<<number<<endl;   //-185.12
cout.width();
cout.setf(ios::right,ios::adjustfield);
cout<<number<<endl;   // -185.12
cout.width();
cout.setf(ios::internal,ios::adjustfield);
cout<<number<<endl;   //- 185.12
return ;
}

格式化输出[part1/标准控制符]的更多相关文章

  1. 【Shell脚本学习15】shell printf命令:格式化输出语句

    printf 命令用于格式化输出, 是echo命令的增强版.它是C语言printf()库函数的一个有限的变形,并且在语法上有些不同. 注意:printf 由 POSIX 标准所定义,移植性要比 ech ...

  2. shell printf格式化输出语句

    printf 命令用于格式化输出, 是echo命令的增强版.它是C语言printf()库函数的一个有限的变形,并且在语法上有些不同. 注意:printf 由 POSIX 标准所定义,移植性要比 ech ...

  3. 格式化输出io:format的奇技淫巧

    格式化输出io:format是我接触Erlang使用的第一个库函数(io:format("Hello World")),随着学习的深入,它也是我debug优先选择最简单直接的工具. ...

  4. shell printf命令:怎样格式化输出语句

    printf 命令用于格式化输出, 是echo命令的增强版.它是C语言printf()库函数的一个有限的变形,并且在语法上有些不同. 注意:printf 由 POSIX 标准所定义,移植性要比 ech ...

  5. shell printf命令:格式化输出语句

    printf 命令用于格式化输出, 是echo命令的增强版.它是C语言printf()库函数的一个有限的变形,并且在语法上有些不同. 注意:printf 由 POSIX 标准所定义,移植性要比 ech ...

  6. 8.Java格式化输出

    JAVA中字符串输出格式 1.使用format函数 System.out.format("%d  %f",10,10.5); 2.使用Formatter类 构造函数Formatte ...

  7. 【Python④】python恼人的字符串,格式化输出

    恼人的字符串 计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理.由于计算机是美国人发明的,因此,最早只有127个字母被编码到计算机里,也就是大小写英文字母.数字和一些符号,这个编码 ...

  8. (Python )格式化输出、文件操作、json

    本节学习Python的格式化输出,文件操作以及json的简单用法 1.格式化输出 将非字符串类型转换成字符串,可以使用函数:str() 或者repr() ,(这两个函数的区别目前我还没搞懂,求解答) ...

  9. 格式化输出[parts/iomanip]

    /* 用ios类中的成员函数来进行IO格式的控制总需要写一条单独的语句,而不能直接嵌入到IO语句中,显得很不方便,因此C++又提供了一种用操作符来控制IO的格式.操作符分为带参和不带参两种,带参的定义 ...

随机推荐

  1. PPTP --VPN配置

    测试:1:根据上面的步骤4,在路由器里查看状态:2:手机热点,共享给你电脑,电脑拨号,进行测试.   参考:http://jingyan.baidu.com/article/90808022ddd6a ...

  2. Android IOS WebRTC 音视频开发总结(十三)-- ice原理

    以前在做一个视频监控项目的时候,刚开始客户没提到要支持P2P,因为服务端是我们自己写的,为了便于处理一些逻辑,全部采用转发的方式,后来客户要求支持P2P,没办法了,后来自己部署了一个STUN服务器(不 ...

  3. MVC开发Markdown编辑器(1)

    MVC markdown MVC开发Markdown编辑器(1) 前言 安装 解析 结束语 前言 想在近段时间通过mvc开发个人博客,编辑器希望是markdown风格的,这样写文字会很方便.首先先解决 ...

  4. 支持在安卓中UI(View)的刷新功能

     这是一款可以支持在安卓中UI(View)的刷新功能,Android中对View的更新有很多种方式,使用时要区分不同的应用场合.我感觉最要紧的是分清:多线程和双缓冲的使用情况.   现在可以尝试理解下 ...

  5. ubuntu 12.04 64位设置兼容32位的实现

    在ubuntu12.04上,要运行32的程序,需要安装32位的兼容库. 以前在10.04上成功安装过,方法是 sudo apt-get install ia32-libs 但是在12.04上遇到了困难 ...

  6. -webkit-filter属性用来干什么

    这两天有看到国外网站纷纷介绍-webkit-filter,开始很迷惑,丫是想要学IE吗?今天看了下,和IE的滤镜没一毛关系啊,而且,效果很赞! 这些滤镜效果最初是用于SVG的,W3C引入到CSS中,然 ...

  7. CentOS下修复grub引导程序

    1.早上装系统,试了好几次.最终grub修复成功! 解决方法大致如下: 开机遇见 grub>的时候 下面看解决方法 首先是既然插上U盘能进系统  那我们插上U盘 正常进入系统  然后看操作 [r ...

  8. 线程间通信--wait和notify

    使用wait.notify方法实现线程间的通信(注意这两个方法都是object的类的方法,换句话说java为所有的对象都提供了这两个方法) 1.wait和notify必须配合synchronized关 ...

  9. ip的正则表达式 完美版

    IP地址的长度为32位2进制,分为4段,每段8位,用十进制数字表示,每段数字范围为0~255,段与段之间用英文句点“.”隔开.例如:IP地址为10.0.0.100. 分析IP地址的每组数特点:百位,十 ...

  10. HOOK API 在多线程时应该注意的问题点

    在使用INLINE HOOK API实现对系统API的拦截时,正常情况下并没有太大问题,但一旦涉及到多线程,不管是修改IAT还是JMP,2种方法均会出现不可预料的问题,特别是在HOOK一些复杂的大型系 ...