C语言中,我们可以通过函数printf和scanf进行格式化控制,而在C++中仍然包含了前者,但还提供了以下两种格式控制的方法:
(1)使用流成员函数进行格式控制;
(2)使用预定义操作符进行格式控制。
流成员函数主要指ios类(流基类)中的成员函数,分别有:
(1)设置状态标志流成员函数setf。
一般格式:long ios::setf(long flags)
,调用格式:流对象.setf(ios::状态标志)
。
ios类的状态标志有:
常量 | 含义 | failbit | eofbit | badbit | 十进制值 |
---|---|---|---|---|---|
ios::failbit | I/O流出现致命错误,可挽回 | 1 | 0 | 0 | 4 |
ios::eofbit | 已到达文件尾 | 0 | 1 | 0 | 2 |
ios::badbit | I/O流出现致命错误,不可挽回 | 0 | 0 | 1 | 1 |
ios::goodbit | 流状态正常 | 0 | 0 | 0 | 0 |
因为状态标志在ios类中定义为枚举值,所以在引用这些值前要加上ios::
,如果有多项标志,中间则用"|"分隔。
(2)清除状态标志流成员函数unsetf。
一般格式:long ios::unsetf(long flags)
调用格式:流对象.unsetf(ios::状态标志)
(3)设置域宽流成员函数width。
一般格式:int ios::width(int n)
调用格式:流对象.width(n); //注:它只对下一个流输出有效,输出完成后,恢复默认值0
(4)设置实数的精度流成员函数precision。
一般格式:int ios::precision(int n)
调用格式:流对象.precision(n);//注:参数n在十进制小数形式输出时代表有效数字。在以fixed形式和scientific形式输出时代表小数位数
(5)填充字符流成员函数fill。
一般格式:char ios::fill(char ch)
调用格式:流对象.fill(ch); //注:当输出值不满宽域时用填充符来填充,默认填充符为空格,它与width函数搭配。
下面用示例来验证:
#include "stdafx.h"
#include
#include
int main()
{
std::cout.setf(std::ios::left|std::ios::showpoint|std::ios::unitbuf);
std::cout.precision(6);
std::cout<<123.45678;
std::cout.width(50);
std::cout.fill('-');
std::cout.unsetf(std::ios::left);//清除状态左对齐
std::cout.setf(std::ios::right);
std::cout<<"十进制小数输出,有效数字为6位"<
结果:
123.457----------------------十进制小数输出,有效数字为6位
123.456780-----------------------固定小数位fixed,小数位为6位
1.234568e+02-----------------------科学计数法表示,小数位为6位
+ 128
0200
0XFF
用ios类中的成员函数来进行IO格式的控制总需要写一条单独的语句,而不能直接嵌入到IO语句中去,显得很不方便。因此C++又提供了一种用操纵符来控制IO的格式。操纵符分为带参和不带参的两种,带参的定义在头文件
中,不带参的定义在
中。下面分别是C++中的预定义操作符:
(1)dec:设置整数基数为10,用于输出和输入;
(2)hex:设置整数基数为16,用于输出和输入;
(3)oct:设置整数基数为8,用于输出和输入;
(4)ws:跳过输入的空格符,用于输入;
(5)endl:输出一个换行符并刷新输出流,用于输出;
(6)ends:插入一个空字符null,通常用来结束一个字符串,用于输出;
(7)flush:刷新一个输出流,用于输出;
(8)setbase(n):设置整数的基数为n(可取0或10代表十进制,8代表八进制和16代表十六进制,默认为0),用于输入和输出;
(9)setfill©:设置填充符(默认为空格),用于输出;
(10)setprecision(n):设置实数精度n,原理和成员函数precision一样,用于输出;
(11)setw(n):设置域宽n,用于输出;
(12)setiosflags(flags):设置指定状态标志,多个用"|"分隔,用于输出和输入;
(13)resetiosflags(flags):清除指定状态标志,多个用"|"分隔,用于输出和输入;
操作符setiosflags(flags)和resetiosflags(flags)的部分状态标志:
状态标志 | 功能 |
---|---|
left | 按域宽左对齐输出 |
right | 按域宽右对齐输出 |
fixed | 定点格式小数输出 |
scientific | 科学计数法输出 |
showpos | 在正数显示“+” |
uppercase | 在以科学计数法和以十六进制输出时字母用大写表示 |
下面用示例来验证:
#include "stdafx.h"
#include
#include //带形参的操纵符必须含有该头文件
#include
int main()
{
std::string str="abcdefg";
std::cout<
结果:
abcdefg
123.457-----------------------科学计数法表示,小数位为6位
123.456780-----------------------固定小数位fixed,小数位为6位
1.2345678e+002-----------------------科学计数法表示,小数位为6位
+ 128
0200
0XFF
除了利用系统预定义的操纵符来进行IO格式的控制外,用户还可以自定义操纵符来合并程序中频繁使用的IO写操作。定义形式如下:
输出流自定义操纵符:
ostream &操纵符名(ostream &s)
{
自定义代码
return s;
}
输入流自定义操纵符
istream &操纵符名(istream &s)
{
自定义代码
return s;
}
返回流对象s很关键,否则操纵符就不能用在流的IO操作序列中。示例验证如下:
#include "stdafx.h"
#include
#include
std::ostream& outputNo(std::ostream& s)
{
//编号格式如:0000001
s<>std::hex;
return s;
}
int main()
{
std::cout<>To16>>a;
std::cout<<"转化为十进制数:"<
结果:
0000008
请输入十六进制的数:ff
转化为十进制数:255
[1]ios.C++ reference