请教设置标志字

chennut 2009-09-23 11:02:45
大家好,我查过有关参考书看到:long flag(long)设置标志字的值,并返回以前所设置的标志字
long flag()返回当前的标志字
请看一下代码:
#include<iostream>
using namespace std;
void main(){
float c=23.56F, d=-101.22F;
cout.width(20);
cout.setf(ios_base::scientific | ios_base::right | ios_base::showpos, ios_base::floatfield);
cout<<c<<"\t"<<d<<"\t"<<endl;
cout.setf(ios_base::fixed | ios_base::showpos, ios_base::floatfield);
cout<<c<<"\t"<<d<<"\t"<<endl;
cout<<cout.flags()<<" "<<123.0<<endl;
cout.flags(513);
cout<<123.0<<endl;
}
请问什么是标志字?这两个函数是有什么作用?
cout的flags()函数究竟为什么输出8705?另外cout.flags(513)这句话是设置什么?
...全文
140 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
nobody@noone 2009-09-24
  • 打赏
  • 举报
回复
一般标志字转成二进制然后就好看了
geochway 2009-09-24
  • 打赏
  • 举报
回复
typedef int fmtflags;
enum fmt_flags {
boolalpha = 0x0001,
dec = 0x0002,
fixed = 0x0004,
hex = 0x0008,
internal = 0x0010,

left = 0x0020,
oct = 0x0040,
right = 0x0080,
scientific = 0x0100,
showbase = 0x0200,
showpoint = 0x0400,
showpos = 0x0800,
skipws = 0x1000,
unitbuf = 0x2000,
uppercase = 0x4000,
adjustfield = left | right | internal,

basefield = dec | oct | hex,
floatfield = scientific | fixed
};
wendll 2009-09-24
  • 打赏
  • 举报
回复
flags()函数或者返回当前流的格式标志,或者为当前流设置标志为f。

c++为标准输入和输出定义了一些格式标志, 它可以通过flags(), setf(), 和 unsetf() 三个函数来控制.

f=cout.flags()返回的值f代表着一套格式(宽度,对齐方式,浮点数的输出精度等等),cout.flags(f)表示把格式设置为f。
zgjxwl 2009-09-24
  • 打赏
  • 举报
回复
msdn ios_base
wanghao111 2009-09-24
  • 打赏
  • 举报
回复
路过,看看
点墨 2009-09-23
  • 打赏
  • 举报
回复

#include <iostream>
using namespace std;
int main()
{
cout<<"1st:"<<cout.flags()<<endl;
cout<<"\tios_base::scientific: "<<ios_base::scientific<<endl;
cout<<"\tNext may be: "<<(cout.flags() | ios_base::scientific)<<endl;
cout.setf(ios_base::scientific);
cout<<"2nd:"<<cout.flags()<<endl;
cout<<"\tios_base::right: "<<ios_base::right<<endl;
cout<<"\tNext may be: "<<(cout.flags() | ios_base::right)<<endl;
cout.setf(ios_base::right);
cout<<cout.flags()<<endl;
getchar();
return 0 ;
}

很明显,标志符的输出都是2的n次方;
一个long类型的每一个bit位代表一种含义,设置标志符也就相当于在相应位上赋1。
cphj 2009-09-23
  • 打赏
  • 举报
回复
ios_base::scientific, ios_base::right等为格式状态,它们按bit位记录,一共32个bits
cout.flags()是将整个32bits一起取出来按long型数据显示
因为前面通过setf设置了一堆bit位,按long型显示就是8705,也就是10001000000001
cout.flags(513)是一次性将32个bits设置为513,也就是1000000001
七号信令分析软件 2.0 一.实现功能及解决问题 1.增加对ISUP消息的分析统计功能; 2.解决DISMSU执行出现非法操作的错误,主要是对ISUP的INF消息和TUP的GSM消息处理有误; 3.解决打开扩展名为大写的“TXT”当作二进制文件分析的错误; 4.更新用户手册,主要增加ISUP消息中的失败原因值的列表 5.解决七号信令分析软件判断跟踪消息的信令点编码为24位还是14位的问题,估计跟踪消息中的一个标志位判断。不需要用户配置。 6.增加打印功能; 7.统计结果的排序问题,可以按数排序; 8.解决通过滚动条无法看到最后一条记录的问题; 9.主被叫号码长度超过29位导致“内部不正确”提示的问题。 10.可以对旧格式的信令文件进行处理后,用此软件进行分析。 具体使用方法见“UserMannua20.lwp”或从程序组中打开“用户手册”。 二.目前已经存在的问题,但难以解决的有: 1.相关信令的查询 当点击某个呼叫时,在出现相关的信令消息之前会有短时间的白屏现象。这是因为程序调用了一个DISMSU.EXE文件产生包含信令消息的文件。但是因为执行之间的同步问题,如果调用DISMSU.EXE结束后立刻打开信令消息文件显示,往往打开的是上一次的结果。所以在显示之前SLEEP 2秒钟。请教过UI的高手,通过在某一个文件中设置标志位来充当信号量,但在实现中发现仍然是老问题。 2.统计速度 对信令消息的统计速度比较慢,可能要忍受一下。我测试用的文件比较小,执行起来还比较快。主要原因可能在于以前的版本只支持TUP消息统计,消息参数都比较少,所以数组开了100个节的空间。考虑到ISUP消息最长为272个,但转换为文本的符表示,还要加空格,基本上是3倍的关系。所以目前的消息长度定位600。这样内存和写文件操作时间都会比较长。 3.不能统计自环消息 目前七号信令分析软件不支持对自环消息的统计,或者说自环统计中认为是成功的呼叫,在用此软件分析后会认为没有后向的应答消息而设置状态为不成功。 三.安装路径 setup目录下存放的是七号信令分析软件 2.0版本的安装盘。

65,209

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧