c++的格式控制
1: 每个iostream对象维持一个控制IO格式化细节的格式状态。标准库定义了一组操纵符来修改对象的格式状态。所谓操纵符是可用作输入或输出操作符的函数或对象。iostream和iomanip头文件中分别定义了一些操纵符,如表所示:
2:
3: iostream中定义的操纵符
4:
5: boolalpha 将真和假显示为字符串
6: * noboolalpha 将真和假显示为1, 0
7: showbase 产生指出数的基数的前缀
8: * noshowbase 不产生记数基数前缀
9: showpoint 总是显示小数点
10: * noshowbase 有小数部分才显示小数点
11: showpos 显示非负数中的+
12: * noshowpos 不显示非负数中的+
13: uppercase 在十六进制中打印0X,科学记数法中打印E
14: * nouppercase 在十六进制中打印0x,科学记数法中打印e
15: * dec 用十进制显示
16: hex 用十六进制显示
17: oct 用八进制显示
18: left 在值的右边增加填充字符
19: right 在值的左边增加填充字符
20: internal 在符号和值之间增加填充字符
21: fixed 用小数形式显示浮点数
22: scientific 用科学记数法显示浮点数
23: flush 刷新ostream缓冲区
24: ends 插入空字符,然后刷新ostream缓冲区
25: endl 插入换行符,然后刷新ostream缓冲区
26: unitbuf 在每个输出操作之后刷新缓冲区
27: * nounitbuf 恢复常规缓冲区刷新
28: * skipws 不为输入操作符跳过空白
29: ws “吃掉”空白
30:
31: 注:带*的是默认状态。
32:
33: iomanip中定义的操纵符
34:
35: setfill(ch) 用ch填充空白
36: setprecision(n) 将浮点精度置为n
37: setw(w) 读写w个字符的值
38: setbase(b) 按基数b输出整数
39:
40: 可以使用flags操作符恢复格式状态
41:
42: 1、不带实参的flags()返回流的当前格式状态。返回值是名为fmtflags的标准库定义类型。
43:
44: 2、flags(arg)接受一个实参并将流格式置为实参所指定的格式。
45:
46: Sample:
47:
48: void display(ostream& os)
49: {
50: //remember the current format state
51: ostream::fmtflags curr_fmt = os.flags();
52: //do output that uses manipulators that change the format state of os
53: os.flags(curr_fmt); //restore the original format state of os
54: }
55:
56:
57:
58:
59:
60: 使用举例:
61:
62: 1、控制布尔值 boolalpha:
63: bool flag = flase;
64:
65: cout << flag << endl; //Display: 0
66:
67: cout << boolalpha << flag << endl; //Display: false
68:
69: 2、控制整形 oct、hex:
70:
71: int ival = 16;
72:
73: cout << ival << endl; //Display: 16
74:
75: cout << oct << ival << endl; //Display: 20
76:
77: cout << hex << ival << endl; //Display: 10
78:
79: 指出输出的基数及形式 showbase:
80:
81: cout << showbase; //Set format that showbase
82: cout << ival << endl; //Display: 16
83: cout << oct << ival << endl; //Display: 020
84: cout << hex << ival << endl; //Display: 0x10
85:
86: cout << uppercase << hex << ival << endl; //Display:0X10
87:
88: cout << noshowbase; //Set the default format
89:
90: 3、指定显示精度 precision setprecision
91:
92: 默认情况下,精度控制显示的数字总位数。显示的时候,将浮点值四舍五入到当前精度。因此,如果精度为4,则3.1415926成为3.142。
93:
94: Sample:
95:
96: float pi = 3.1415926535;
97: //cout.precision reports current precision value
98: cout << cout.precision() << " " << pi << endl; //Display: 6 3.14159
99:
100: //one way to set format
101: cout.precision(8);
102: cout << pi << endl; //Display: 3.1415927
103: //another way to set format
104: cout << setprecision(3) << pi << endl; //Display: 3.14
105:
106: 4、控制浮点数的记数法
107:
108: 默认情况下,用于显示浮点值的记数法取决于数的大小,如果数很大或很小,将按科学记数法显示,否则,使用固定位数的小数。可以使用scientific或fixed来修改浮点数的默认记数法。但是要恢复默认记数法则必须调用unsetf成员来取消它们所做的改变。
109:
110: cout.unsetf(ofstream::floatfield); //reset to default handling for notation
111:
112: Sample:
113:
114: cout << sqrt(2.0) << endl; //Dispaly: 1.41421
115: cout << scientific << sqrt(2.0) << endl; //Display: 1.414214e+00
116: cout << fixed << sqrt(2.0) << endl; //Display: 1.414214
117: cout.unsetf(ostream::floatfield);
118:
119: 5、填充输出 setw left right internal setfill:
120:
121: int i = -6;
122: double d = 3.14159;
123: cout << setw(12) << i << endl;
124: cout << setw(12) << d << endl;
125: cout << left << setw(12) << i << endl;
126: cout << setw(12) << d << endl;
127: cout << right;
128: cout << internal << setw(12) << i << endl;
129: cout << setw(12) << d << endl;
130: cout << setfill('$') << setw(12) << i << endl;
131: cout << setw(12) << d << endl;
132: cout << setfill(' ');
133:
134: Display:
135:
136:
137:
138: 5、控制输入格式化
139:
140: 默认情况下, 输入操作符忽略空白。如:
141:
142: while(cin >> ch)
143: cout << ch;
144:
145: 给定输入序列:
146:
147: a b c(分别为一个空格和两个空格)
148:
149: d
150:
151: 循环执行四次从字符a读到d,跳过介于其间的空白。所以输出abcd.
152:
153: 如果是:
154:
155: cin >> noskipws;
156: while(cin >> ch)
157: cout << ch;
158: cin >> skipws;
159:
160: 则同样的输入将输出:
161:
162: a b c
163:
164: d
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
c++的格式控制的更多相关文章
- 9月5日网页基础知识 通用标签、属性(body属性、路径、格式控制) 通用标签(有序列表、无序列表、常用标签)(补)
网页基础知识 一.HTML语言 HTML语言翻译汉语为超文本标记语言. 二.网页的分类 1.静态页面:在静态页面中修改网页内容实际上就是修改网页原代码,不能从后台操作,数据来只能来源于原于代码.静态网 ...
- html标签,格式控制标签,内容容器标签,超链接标签,图片标签,表格
打开DREAMWEAVER,新建HTML,如下图: body的属性: bgcolor 页面背景色 background 背景壁纸.图片 text 文字颜色 topmargin 上边距 leftm ...
- html body的属性 格式控制标签 内容容器标签 超链接标签 图片标签 表格
一.body的属性 <body bgcolor 页面背景色 background 背景壁纸.图片 text文字颜色 topmargin上边距 leftmargin左边距 rightmargi ...
- C++文件操作(输入输出、格式控制、文件打开模式、测试流状态、二进制读写)
1.向文件写数据 头文件#include <ofstream> ①Create an instance of ofstream(创建ofstream实例) ②Open the file w ...
- printf的格式控制的完整格式
printf的格式控制的完整格式:% - 0 m.n l或h 格式字符下面对组成格式说明的各项加以说明:①%:表示格式说明的起始符号,不可缺少.②-:有-表示左对齐输出,如省略表示右对齐输出 ...
- C 语言 printf格式控制详解
闲来无事,整理了一下C语言printf() 的格式控制语句. PS:详细来源于网络. printf的格式控制的完整格式: % - 0 m.n l或h 格式字符 下面对组成格式说明的各项加以说 ...
- printf格式控制详解
format 参数输出的格式,定义格式为 %[flags][width][.precision][length]specifier specifier在最后面.定义了数据类型. Where the s ...
- C++学习笔记1(扩充:C++中的格式控制)
前一章,我们了解了再C++中的标准的输入输出问题,那么肯能就有人会问了再C语言中我们可以灵活的控制输出和显示,那么再再C++中可以实现吗?我的回答是当然可以的,只不过再C++中的控制可能相比较而言要比 ...
- 无符号整型 unsigned int、unsigned long、usigned long long、size_t 比较和格式控制
位数比较 由于数据的长度和平台相关,所以基于 64 位系统比较. Windows Linux unsigned int 32 bits/4294967295 32 bits unsigned long ...
- python xlwt写excel格式控制 颜色、模式、编码、背景色
关于写excel的格式控制,比如颜色等等 import xlwt from datetime import datetime font0 = xlwt.Font() font0.name = 'Tim ...
随机推荐
- python uwsgi 部署以及优化
这篇文章其实两个月之前就应该面世了,但是最近琐事.烦心事太多就一直懒得动笔,拖到现在才写 一.uwsgi.wsgi.fastcgi区别和联系 参见之前的文章 http://www.cnblogs.co ...
- 面试题思考:Java 8 / Java 7 为我们提供了什么新功能
Java 7 的7个新特性 1.对集合类的语言支持: 2.自动资源管理: 3.改进的通用实例创建类型推断: 4.数字字面量下划线支持: 5.switch中使用string: 6.二进制字面量: 7.简 ...
- sublime text 3 并列显示
alt+shift+1:显示一列 alt+shift+2:显示二列 alt+shift+3:显示三列 ......
- ryu的RESTAPI简介——我主要用于下发和查看流表
一.Rest API简介 REST即表述性状态传递(RepreSentational State Transfer),是一种针对网络应用的设计和开发方式,可以降低开发的复杂性,提高系统的可伸缩性. 表 ...
- cocos2d-X学习之主要类介绍:场景(CCScene)
场景(CCScene) 类结构: CCScene主要有以下两个函数: bool init () //初始化函数 static CCScene * node (void) //生CCScene 作为 ...
- 用RSS订阅微信公众号
现在用RSS的人应该不多了,不过还是写一下吧. 一.付费服务:今天看啥 1.付费原因: 目前,网上几乎没有免费的用RSS订阅微信公号的方法,所以我推荐的是付费方法: 具体使用的服务是今天看啥,服务还是 ...
- ClickHouse RPM packages installation from packagecloud.io
Table of Contents Introduction Script-based installation Install script Install packages after scrip ...
- 第二课补充01——redis-cli命令行详解、string类型、list类型、hash类型命令操作详解
一. redis-cli命令行参数 1.-x参数:从标准输入读取一个参数: [问题] [解决] 因为echo命令是默认带有回车\n的,不带回车需要echo –n命令: echo -n "ha ...
- 高性能网站服务器的架设优化-Nginx优化
一:对于高性能网站 ,请求量大,如何支撑?思路 在网站架构设计中,大家一定对 LNMP (Linux Nginx Mysql Php) 不陌生.LNMP 确实是一个非常优秀的架构,秉承着自由,开放,高 ...
- python基础-第十三篇-13.2Web框架之Tornado
Tornado是非阻塞异步web frame,而且速度相当快,得力于其非阻塞的方式和对epoll的运用 Tornado每秒可以处理数以千计的链接,所以它可以有效的处理C10K问题 下载安装 pip3 ...