C++流操纵算子(格式控制)


       输入/输出的数据没有指定格式,它们都按缺省的格式输入/输出。然而,有时需要对数据格式进行控制。这时需利用ios类中定义的格式控制成员函数,通过调用它们来完成格式的设置。


ios类的格式控制函数如下所示:


long flags( ) const返回当前的格式标志。
long flays(long newflag)设置格式标志为newflag,返回旧的格式标志。
long setf(long bits)   设置指定的格式标志位,返回旧的格式标志。
long setf(long bits,long field)将field指定的格式标志位置为bits,返回旧的格式标志。
 long unsetf(long bits) 清除bits指定的格式标志位,返回旧的格式标志。
long fill(char c)  设置填充字符,缺省条件下是空格。
  char fill( )  返回当前填充字符。
int precision(int val)  设置精确度为val,控制输出浮点数的有效位,返回旧值。
int precision( )返回旧的精确度值。
int width(int val)      设置显示数据的宽度(域宽),返回旧的域宽。
int width( )  只返回当前域宽,缺省宽度为0。这时插入操作能按表示数据的最小宽度显示数据。 


预定义的操纵算子
    使用成员函数控制格式化输入输出时,每个函数调用需要写一条语句,尤其是它不能用在插入或提取运算符的表达式中,而使用操纵算子,则可以在插入和提取运算符的表达式中控制格式化输入和输出。在程序中使用操纵算字必须嵌入头文件
iomanip.h

dec十进制的输入输出
 hex十六进制的输入输出
 oct  八进制的输入输出
ws  提取空白字符
 ends  输出一个nul字符
endl  输出一个换行字符,同时刷新流
flush刷新流
resetiosflags(long)请除特定的格式标志位
setiosflags(long) 设置特定的格式标志位
setfill(char)设置填充字符
setprecision(int)设置输出浮点数的精确度
 setw(int)设置域宽格式变量

其它流函数

错误处理
    在对一个流对象进行I/O操作时,可能会产生错误。当错误发生时,错误的性质被记录在ios类的一个数据成员中。
ios类中定义的描述错误状态的常量:

 

goodbit 没有错误,正常状态  eofbit 到达流的结尾   
failbitI/O操作失败,清除状态字后,可以对流继续进行操作。
badbit试图进行非法操作,清除状态字后,流可能还可以使用。
hardfail致命错误,不可恢复的错误。


ostream类的成员函数
流的其它成员函数可以从流中读取字符或字符串,对流进行无格式化的输入 输出操作,以及直接控制对流的I/O操作。

 

返回类型ios类的成员描      述
ostream*tie(ostream*)   将当前流与指定的输出流连接起来。每当需要 读取当前流时,连接的流会自动刷新。C++流库已用cin.tie(cout)将输入流与输出流连接起来。要取消与输出流的连接可采用is.tie(0)
ostream*tie( )返回指向连接流的指针


 

返回类型ostream类的成员描      述
ostream&put(char ch)向流中输出一个字符ch,不进行任何转换
ostream&write(char*,int)向流中输出指定长度的字符串,不进行转换
ostream& flush( )刷新流,输出所有缓冲的但还未输出的数据
ostream&seekp(streampos)移动流的当前指针到给定的绝对位置
ostream&seekp(sereamoff,seek_dir)流的当前指针类似与文件的当前指针
streamposteelp( )返回流的当前指针的绝对位置

istream类的成员函数

 

返回类型istream类的成员描        述
intget( )读取并返回一个字符
istream&get(char&c)读取字符并存入c中
istream&get(char*ptr,int len,char delim='')读取指定的字符到缓冲区中,直到遇到指定的分界符为止,分界符不填入缓冲区。
istream&getline(char*ptr,int len,char delim='')与get(char*ptr,int len,chardelim ='') 类似,但将分界符填入缓冲区。
istream& putback( )将最近读取的字符放回流中
istream&read(char*,int)读取规定长度的字符串到缓冲区中
intpeek( ) 返回流中下一个字符,但不移动文件指针
istream&seekg(streampos)移动当前指针到一绝对地址
istream& seekg(streampos,seek_dir)移动当前指针到一相对地址
streampostellg( )返回当前指针
istream&ignore(int n=1,delim=EOF)跳过流中几个字符,或直到遇到指定的分界符为止

关于::符号的探讨

  仔细查找了一下ios类控制符的源文件,可以追溯到头文件ios_base.h,其中包含了很多控制流的变量或方法,而这些成员都被包围在了命名空间std中,代码如下所示。因此,流控制符是std命名空间中的静态常量,::则代表了这些常量来自于std这个命名空间。

 1 // 27.4.2.1.2  Type ios_base::fmtflags
 2     /**
 3      *  @brief This is a bitmask type.
 4      *
 5      *  @c "_Ios_Fmtflags" is implementation-defined, but it is valid to
 6      *  perform bitwise operations on these values and expect the Right
 7      *  Thing to happen.  Defined objects of type fmtflags are:
 8      *  - boolalpha
 9      *  - dec
10      *  - fixed
11      *  - hex
12      *  - internal
13      *  - left
14      *  - oct
15      *  - right
16      *  - scientific
17      *  - showbase
18      *  - showpoint
19      *  - showpos
20      *  - skipws
21      *  - unitbuf
22      *  - uppercase
23      *  - adjustfield
24      *  - basefield
25      *  - floatfield
26     */
27     typedef _Ios_Fmtflags fmtflags;
28 
29     /// Insert/extract @c bool in alphabetic rather than numeric format.
30     static const fmtflags boolalpha =   fmtflags(__ios_flags::_S_boolalpha);
31 
32     /// Converts integer input or generates integer output in decimal base.
33     static const fmtflags dec =         fmtflags(__ios_flags::_S_dec);
34 
35     /// Generate floating-point output in fixed-point notation.
36     static const fmtflags fixed =       fmtflags(__ios_flags::_S_fixed);
37 
38     /// Converts integer input or generates integer output in hexadecimal base.
39     static const fmtflags hex =         fmtflags(__ios_flags::_S_hex);
40 
41     /// Adds fill characters at a designated internal point in certain
42     /// generated output, or identical to @c right if no such point is
43     /// designated.
44     static const fmtflags internal =    fmtflags(__ios_flags::_S_internal);
45 
46     /// Adds fill characters on the right (final positions) of certain
47     /// generated output.  (I.e., the thing you print is flush left.)
48     static const fmtflags left =        fmtflags(__ios_flags::_S_left);
49 
50     /// Converts integer input or generates integer output in octal base.
51     static const fmtflags oct =         fmtflags(__ios_flags::_S_oct);
52 
53     /// Adds fill characters on the left (initial positions) of certain
54     /// generated output.  (I.e., the thing you print is flush right.)
55     static const fmtflags right =       fmtflags(__ios_flags::_S_right);
56 
57     /// Generates floating-point output in scientific notation.
58     static const fmtflags scientific =  fmtflags(__ios_flags::_S_scientific);
59 
60     /// Generates a prefix indicating the numeric base of generated integer
61     /// output.
62     static const fmtflags showbase =    fmtflags(__ios_flags::_S_showbase);
63 
64     /// Generates a decimal-point character unconditionally in generated
65     /// floating-point output.
66     static const fmtflags showpoint =   fmtflags(__ios_flags::_S_showpoint);
67 
68     /// Generates a + sign in non-negative generated numeric output.
69     static const fmtflags showpos =     fmtflags(__ios_flags::_S_showpos);
70 
71     /// Skips leading white space before certain input operations.
72     static const fmtflags skipws =      fmtflags(__ios_flags::_S_skipws);
73 
74     /// Flushes output after each output operation.
75     static const fmtflags unitbuf =     fmtflags(__ios_flags::_S_unitbuf);
76 
77     /// Replaces certain lowercase letters with their uppercase equivalents
78     /// in generated output.
79     static const fmtflags uppercase =   fmtflags(__ios_flags::_S_uppercase);
80 
81     /// A mask of left|right|internal.  Useful for the 2-arg form of @c setf.
82     static const fmtflags adjustfield = fmtflags(__ios_flags::_S_adjustfield);
83 
84     /// A mask of dec|oct|hex.  Useful for the 2-arg form of @c setf.
85     static const fmtflags basefield =   fmtflags(__ios_flags::_S_basefield);
86 
87     /// A mask of scientific|fixed.  Useful for the 2-arg form of @c setf.
88     static const fmtflags floatfield =  fmtflags(__ios_flags::_S_floatfield);

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值