std::cout, std::wcout
定义在头文件 <iostream> 中 |
||
extern std::ostream cout; |
(1) | |
extern std::wostream wcout; |
(2) | |
全局对象 std::cout
和 std::wcout
控制输出到一个实现定义类型的流缓冲区(从 std::streambuf 派生),与标准 C 输出流 stdout 关联。
这些对象保证在第一次构造类型为 std::ios_base::Init 的对象期间或之前初始化,并且可以在静态对象的构造函数和析构函数中使用,这些静态对象具有 有序初始化(只要 <iostream> 在对象定义之前包含)。
除非 std::ios_base::sync_with_stdio(false) 已发出,否则可以安全地从多个线程并发访问这些对象,以进行格式化和非格式化输出。
根据 std::cin 的规范,std::cin.tie() 返回 &std::cout。这意味着对 std::cin
的任何输入操作都会执行 std::cout.flush()(通过 std::basic_istream::sentry 的构造函数)。类似地,std::wcin.tie() 返回 &std::wcout.
根据 std::cerr 的规范,std::cerr.tie() 返回 &std::cout。这意味着对 std::cerr
的任何输出操作都会执行 std::cout.flush()(通过 std::basic_ostream::sentry 的构造函数)。类似地,std::wcerr.tie() 返回 &std::wcout。 (自 C++11 起)
[编辑] 备注
名称中的 'c' 指的是 "字符" (stroustrup.com 常见问题解答);cout
表示 "字符输出",wcout
表示 "宽字符输出"。
由于 动态初始化 模板化 变量是无序的,因此不能保证在开始初始化此类变量之前 std::cout
已初始化为可使用状态,除非已构造类型为 std::ios_base::Init 的对象。
[编辑] 示例
#include <iostream> struct Foo { int n; Foo() { std::cout << "static constructor\n"; } ~Foo() { std::cout << "static destructor\n"; } }; Foo f; // static object int main() { std::cout << "main function\n"; }
输出
static constructor main function static destructor
[编辑] 另请参阅
初始化标准流对象 ( std::ios_base 的公共成员类) | |
写入标准 C 错误流 stderr,无缓冲 (全局对象) | |
写入标准 C 错误流 stderr (全局对象) | |
与输入流关联的 FILE* 类型表达式与输出流关联的 FILE* 类型表达式与错误输出流关联的 FILE* 类型表达式(宏常量) |