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::fixedios::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;

亲自试一试