#include 略解

iomanip,在C++程序里面经常见到下面的头文件#include ,io代表输入输出,manip是manipulator(操纵器)的缩写(在c++上只能通过输入缩写才有效)。

外文名

iomanip

含    义

C++程序中的头文件

开    头

#include

性    质

操纵运算子

作用

主要是对cin,cout之类的一些操纵运算子,比如setfill,setw,setbase,setprecision等等。它是I/O流控制头文件,就像C里面的格式化输出一样.以下是一些常见的控制函数的:

dec 置基数为10 相当于"%d"

hex 置基数为16 相当于"%X"

oct 置基数为8 相当于"%o"

setfill( 'c' ) 设填充字符为c

setprecision( n ) 设显示有效数字为n位

setw( n ) 设域宽为n个字符

这个控制符的意思是保证输出宽度为n。如:

cout << setw( 3 ) << 1 << setw( 3 ) << 10 << setw( 3 ) << 100 << endl; 输出结果为

_ _1_10100 (默认是右对齐)当输出长度大于3时(<<1000),setw(3)不起作用。

▲setw(n)用法: 通俗地讲就是预设宽度

如 cout<

结果是:

(空格)(空格)255

▲setfill(char c) 用法 : 就是在预设宽度中如果已存在没用完的宽度大小,则用设置的字符c填充

如 cout<

结果是:

@@255

应当指出,setw只作用于紧随其后的部分,例如

cout<

▲setbase(int n) : 将数字转换为 n 进制.

如 cout<

cout<

cout<

结果是:

(空格)(空格)377

(空格)(空格) 255

(空格)(空格)(空格) f f

▲ setprecision(long f)方法的用法

使用setprecision(n)可控制输出流显示浮点数的数字个数。C++默认的流输出数值有效位是6。

如果setprecision(n)与setiosflags(ios::fixed)合用,可以控制小数点右边的数字个数。setiosflags(ios::fixed)是用定点方式表示实数。

如果与setiosflags(ios::scientific)合用, 可以控制指数表示法的小数位数。setiosflags(ios::scientific)是用指数方式表示实数。

setiosflags(ios::fixed) 固定的浮点显示

setiosflags(ios::scientific) 指数表示

setiosflags(ios::left) 左对齐

setiosflags(ios::right) 右对齐

setiosflags(ios::skipws) 忽略前导空白

setiosflags(ios::uppercase) 16进制数大写输出

setiosflags(ios::lowercase) 16进制小写输出 //VS2010中该方法已不使用,意外使用显示没有该成员错误。

setiosflags(ios::showpoint) 强制显示小数点

setiosflags(ios::showpos) 强制显示符号

▲ resetflags(long f)方法的用法

该方法是setiosflags方法的反向方法,即清除之前语句中所使用的setiosflags设定的格式,恢复为默认格式。

举例:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

//此程序输出通过Microsoft Visual C++ 2017运行得出。

// iomanip.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。

#include "pch.h"

#include 

#include

usingnamespacestd;


intmain()

{

    cout << 12345.0 << endl;//输出"12345"

    cout << setiosflags(ios::fixed) << setprecision(3) << 1.2345 << endl;//输出"1.234"(遵循四舍六入五成双的原则,而不是四舍五入的原则)

    cout << resetiosflags(ios::fixed);//需要用resetiosflags()函数清除前面的输出格式

    cout << setiosflags(ios::scientific) << 12345.0 << endl;//输出"1.235e+04"

    cout << resetiosflags(ios::scientific);//需要用resetiosflags()函数清除前面的输出格式

    cout << setiosflags(ios::fixed) << setprecision(3) << 12345.0 << endl;//输出"12345.000"

    return0;

}


// 运行程序: Ctrl + F5 或调试 >“开始执行(不调试)”菜单

// 调试程序: F5 或调试 >“开始调试”菜单


// 入门提示: 

//   1. 使用解决方案资源管理器窗口添加/管理文件

//   2. 使用团队资源管理器窗口连接到源代码管理

//   3. 使用输出窗口查看生成输出和其他消息

//   4. 使用错误列表窗口查看错误

//   5. 转到“项目”>“添加新项”以创建新的代码文件,或转到“项目”>“添加现有项”以将现有代码文件添加到项目

//   6. 将来,若要再次打开此项目,请转到“文件”>“打开”>“项目”并选择 .sln 文件

输出分别为:

12345

1.234

1.235e+04

12345.000

你可能感兴趣的:(#include 略解)