C++ cout 对象
定义和用法
cout
对象用于输出值/打印文本。
使用 cout
最常见的方式是与 <<
插入运算符一起使用。插入运算符根据变量的数据类型决定如何表示该变量或字面值。
cout << "Hello World!";
可以在同一行中多次使用插入运算符来输出多个值:
cout << "The answer is: " << x;
注意:cout
对象在 <iostream>
头文件中定义。
实例
使用 cout
对象输出不同类型的数据:
string myStr = "Hello World!"; bool myBool = false; int myInt = 50; float myFloat = 19.99; cout << myStr << "\n"; cout << myBool << "\n"; cout << myInt << "\n"; cout << myFloat << "\n";
操纵符
操纵符允许您更改输出的格式。它们与 <<
插入运算符一起使用的方式与字面值和变量相同,并且影响它们之后的输出。
除了 setw()
之外,操纵符的效果会一直持续,直到另一个操纵符更改它。
下表列出了一些有用的操纵符:
操纵符 | 描述 | 示例 |
---|---|---|
boolalpha | 将布尔值显示为 "true" 和 "false",而不是 "1" 和 "0"。 | cout << boolalpha << false; |
dec | 将整数表示为十进制数字。 | cout << dec << 12; |
endl |
输出换行符。 此操纵符还会刷新输出缓冲区,这使得它比打印 \n 效率更低。 |
cout << "Line 1" << endl << "Line 2"; |
ends |
输出用于结束 C 风格字符串的空终止字符。 主要用于写入文件时。 |
cout << "Hello World!" << ends; |
fixed | 用固定的小数位数表示浮点数。小数位数可以通过 setprecision() 操纵符设置。 | cout << fixed << 19.99; |
hex | 将整数表示为十六进制数字。 | cout << hex << 12; |
internal | 如果指定了宽度(使用 setw() 操纵符),数字将左对齐符号,而值右对齐,其他数据类型将右对齐输出。 | cout << setw(10) << internal << -12345; |
left | 如果指定了宽度(使用 setw() 操纵符),将输出左对齐。 | cout << setw(10) << left << "Hello"; |
noboolalpha | 用于重置 boolalpha 操纵符所做的更改。 | cout << noboolalpha << false; |
noshowbase | 用于重置 showbase 操纵符所做的更改。 | cout << hex << noshowbase << 12; |
noshowpoint | 用于重置 showpoint 操纵符所做的更改。 | cout << noshowpoint << 12345.0; |
noshowpos | 用于重置 showpos 操纵符所做的更改。 | cout << noshowpos << 12; |
nouppercase | 用于重置 uppercase 操纵符所做的更改。 | cout << hex << nouppercase << 12; |
oct | 将整数表示为八进制数字。 | cout << oct << 12; |
right | 如果指定了宽度(使用 setw() 操纵符),将输出右对齐。 | cout << setw(10) << right << "Hello"; |
scientific |
用科学计数法表示浮点数。 小数位数可以通过 setprecision() 操纵符设置。 |
cout << scientific << 19.99; |
setfill() |
选择一个字符作为填充字符。 需要 <iomanip> 库。 |
cout << setfill('.') << setw(10) << 19.99; |
setprecision() |
选择浮点数的精度。 如果使用 fixed 或科学计数法操纵符,则指定小数位数;否则,指定有效数字位数。 需要 <iomanip> 库。 |
cout << setprecision(4) << 12.3456; |
setw() |
指定下一个输出的最小字符宽度。 如果输出不够宽,则添加填充以填满剩余空间。 需要 <iomanip> 库。 |
cout << setw(10) << "Hello"; |
showbase | 在将整数表示为十六进制或八进制时,在数字前加上 "0x" 或 "0" 以显示其基数。 | cout << hex << showbase << 12; |
showpoint | 即使不需要,也总是显示浮点数的小数点。 | cout << showpoint << 12345.0; |
showpos | 总是在正数旁边显示 + 号。 | cout << showpos << 12; |
uppercase | 将十六进制数字和科学计数法中的 "e" 表示为大写。 | cout << hex << uppercase << 12; |
实例
使用操纵符更改输出的格式:
// 布尔值 cout << "Booleans\n"; cout << false << "\n"; cout << boolalpha << false << "\n"; // 十六进制和八进制数字 cout << "\nHexadecimal and octal numbers\n"; int myInt = 14; cout << dec << myInt << "\n"; cout << hex << myInt << "\n"; cout << oct << myInt << "\n"; cout << showbase << uppercase; cout << hex << myInt << "\n"; cout << oct << myInt << "\n"; cout << dec; // 浮点数 cout << "\nFloating point numbers\n"; float myFloat = 19.99; cout << myFloat << "\n"; cout << showpos << showpoint << 12345.0 << "\n"; cout << noshowpos << noshowpoint; cout << fixed << myFloat << "\n"; cout << scientific << myFloat << "\n"; // 对齐 cout << "\nAlignment\n"; cout << setw(10) << left << "Left" << "\n"; cout << setw(10) << right << "Right" << "\n"; cout << setw(10) << internal << -12345 << " (Internal)\n";
方法
cout
对象还具有方法,可以执行与 <<
插入运算符相同的操作。
输出方法
cout.write(str, n)
方法输出 char
数组 str 中的前 n 个字符,不进行任何格式化。
实例
char myStr[] = "Hello World!"; cout.write(myStr, 5);
cout.put(c)
方法输出指定的字符 c,不进行任何格式化。
实例
char grade = 'B'; cout.put(grade);
格式化方法
cout.precision(p)
方法指定用于表示浮点数的位数。默认情况下,它指定要显示的有效数字位数。如果启用了 ios::fixed
或 ios::scientific
标志,则它指定小数点后的位数。
实例
cout.precision(4); cout << 12.3456;
cout.width(w)
方法指定下一个输出应占用的最小字符宽度。如果输出没有足够的字符,则将添加填充字符以填满剩余空间。默认情况下,填充字符是空格,并且添加在左侧,以便内容右对齐。可以使用下面“标志”部分中描述的 ios::adjustfield
标志之一来更改对齐方式。
实例
cout.width(10); cout << 5 << "\n"; cout.width(10); cout << 25 << "\n"; cout.width(10); cout << 125 << "\n";
cout.fill(c)
方法指定将使用哪个字符作为填充字符。
实例
cout.fill('.'); cout.width(10); cout << 5 << "\n"; cout.width(10); cout << 25 << "\n"; cout.width(10); cout << 125 << "\n";
标志
setf()
和 unsetf()
方法用于设置或取消设置更改输出格式的标志。有多种不同的标志。某些标志属于一个组,在这种情况下,setf()
方法应该有一个第二个参数,指定它属于哪个组,以便可以重置该组中的其他标志。
标志 | 语法 | 描述 |
---|---|---|
ios::boolalpha | cout.setf(ios::boolalpha) | 将布尔值显示为 "true" 和 "false",而不是 "1" 和 "0"。 |
ios::showbase | cout.setf(ios::showbase) | 在将整数表示为十六进制或八进制时,在数字前加上 "0x" 或 "0" 以表示其基数。 |
ios::showpoint | cout.setf(ios::showpoint) | 即使不需要,也始终显示浮点数的十进制点。 |
ios::showpos | cout.setf(ios::showpos) | cout.setf(ios::showpos))始终在正数旁边显示 + 号。 |
ios::uppercase | cout.setf(ios::uppercase) | 将十六进制数字和科学计数法中的 "e" 以大写形式表示。 |
ios::dec | cout.setf(ios::dec, ios::basefield) |
将整数表示为十进制数字。 属于 ios::basefield 组。 |
ios::hex | cout.setf(ios::hex, ios::basefield) |
将整数表示为十六进制数字。 属于 ios::basefield 组。 |
ios::oct | cout.setf(ios::oct, ios::basefield) |
将整数表示为八进制数字。 属于 ios::basefield 组。 |
ios::fixed | cout.setf(ios::fixed, ios::floatfield) |
以固定的小数位数表示浮点数。 小数位数可以通过 cout.precision() 方法设置。 属于 ios::floatfield 组。 |
ios::scientific | cout.setf(ios::scientific, ios::floatfield) |
以科学计数法表示浮点数。 小数位数可以通过 cout.precision() 方法设置。 属于 ios::floatfield 组。 |
ios::internal | cout.setf(ios::internal, ios::adjustfield) |
如果指定了宽度,对于数字,符号左对齐而值右对齐;对于其他数据类型,输出右对齐。 属于 ios::adjustfield 组。 |
ios::left | cout.setf(ios::left, ios::adjustfield) |
如果指定了宽度,将输出左对齐。 属于 ios::adjustfield 组。 |
ios::right | cout.setf(ios::right, ios::adjustfield) |
如果指定了宽度,将输出右对齐。 属于 ios::adjustfield 组。 |
实例
使用标志符改变输出格式:
// 布尔值 cout << "布尔值\n"; cout << false << "\n"; // 默认输出 0 cout.setf(ios::boolalpha); // 设置布尔值输出为 true/false cout << false << "\n"; // 输出 false // 十六进制和八进制数 cout << "\n十六进制和八进制数\n"; int myInt = 14; cout << myInt << "\n"; // 默认输出十进制 cout.setf(ios::hex, ios::basefield); // 设置为十六进制 cout << myInt << "\n"; // 输出十六进制 cout.setf(ios::oct, ios::basefield); // 设置为八进制 cout << myInt << "\n"; // 输出八进制 cout.setf(ios::showbase); // 显示基数前缀 cout.setf(ios::uppercase); // 大写字母 cout.setf(ios::hex, ios::basefield); // 再次设置为十六进制 cout << myInt << "\n"; // 输出带前缀的十六进制 cout.setf(ios::oct, ios::basefield); // 再次设置为八进制 cout << myInt << "\n"; // 输出带前缀的八进制 cout.setf(ios::dec, ios::basefield); // 恢复为十进制 // 浮点数 cout << "\n浮点数\n"; float myFloat = 19.99; cout << myFloat << "\n"; // 默认输出 cout.setf(ios::fixed, ios::floatfield); // 设置为固定小数格式 cout << myFloat << "\n"; // 输出固定小数格式 cout.setf(ios::scientific, ios::floatfield); // 设置为科学计数法 cout << myFloat << "\n"; // 输出科学计数法 cout.unsetf(ios::floatfield); // 取消浮点数格式设置 cout.setf(ios::showpos); // 显示正号 cout.setf(ios::showpoint); // 显示小数点 cout << 12345.0 << "\n"; // 输出带正号和小数点的数 // 对齐 cout << "\n对齐\n"; cout.setf(ios::left, ios::adjustfield); // 设置为左对齐 cout << setw(10) << "Left" << "\n"; // 左对齐输出 cout.setf(ios::right, ios::adjustfield); // 设置为右对齐 cout << setw(10) << "Right" << "\n"; // 右对齐输出 cout.setf(ios::internal, ios::adjustfield); // 设置为内部对齐 cout << setw(10) << 12345.0 << " (Internal)\n"; // 内部对齐输出 return 0;