c++输入输出流 c++ cin与cout格式化输出【方法】
发表时间:2026-01-01 00:00:00
文章作者:冰火之心
浏览次数:
C++中cin/cout格式化需用操纵符和流成员函数:ios_base::flags控制持久格式状态,setw仅对下一项生效且须配setfill,left/right/internal控制对齐。
在C++中,cin和cout是标准输入输出流的核心工具,但默认行为较简单。要实现对齐、精度控制、进制切换等格式化效果,需借助操纵符(manipulators)和流成员函数。关键在于理解哪些设置是持久的(如进制、填充字符),哪些是一次性的(如setw),以及如何组合使用。
用ios_base::flags控制全局格式状态
每个流对象(如cout)内部维护一组格式标志,决定数字进制、符号显示、浮点表示方式等。可用setf()和unsetf()修改,也可用flags()整体替换。
-
cout.setf(ios_base::hex, ios_base::basefield);—— 设为十六进制(自动清除dec/oct) -
cout.setf(ios_base::showbase | ios_base::uppercase);—— 显示0x前缀且字母大写 -
cout.unsetf(ios_base::floatfield);—— 清除科学计数法/定点模式,恢复默认浮点输出
用setw、setfill、left/right/flush做字段宽度与对齐
setw(n)只对**下一个输出项**生效,必须配合setfill(c)指定填充字符(默认空格)。对齐由left、right、internal控制,影响符号/前缀与数值间的填充位置。
cout → 输出"00000042"cout → 左对齐字符串,右对齐数字,各自占10位cout → 输出"-00123"(符号左、数值右、中间填0)
控制浮点数精度与输出形式
浮点数格式由两个独立维度控制:有效数字位数(precision())和表示形式(定点fixed / 科学计数scientific / 默认defaultfloat)。
-
cout.precision(3);—— 设置总有效位数为3(对12.345输出"12.3") cout →"3.14"(小数点后2位)cout →"1.2345e+03"- 注意:
setprecision(n)会同时修改precision()值,并影响后续所有浮点输出,直到再次调用
输入流cin的常用格式控制技巧
cin本身不提供类似setw的宽度限制,但可通过width()临时设定最大读取字符数(仅对>>字符串有效),或用getline()配合ws跳过空白。
-
cin.width(5); char buf[6]; cin >> buf;—— 最多读5个字符(自动加\0) -
ci—— 先跳过前导空白(含换行),再读整行
n >> ws; getline(cin, s); - 用
cin.ignore(n, delim)丢弃最多n个字符,直到遇到delim(常用于清空缓冲区) - 检查输入失败:
if (!(cin >> x)) { cin.clear(); cin.ignore(1000, '\n'); }—— 清错误状态并跳过非法输入

n >> ws; getline(cin, s);







