std::clog, std::wclog
来自cppreference.com
在标头 <iostream> 定义 | ||
externstd::ostream clog; | (1) | |
externstd::wostream wclog; | (2) | |
全局对象 std::clog
和 std::wclog
控制实现定义类型(派生于 std::streambuf)的流缓冲的输出,它与标准 C 输出流 stderr 关联,但与 std::cerr/std::wcerr 不同,不自动冲洗这些流,且 cout
并不自动与这些流 tie()
。
保证在首次构造 std::ios_base::Init 前或期间初始化这些对象,且它们可以在拥有有序初始化的静态对象的构造及析构函数中使用(只要在定义该对象前包含 <iostream>)。
除非发出了 sync_with_stdio(false),从多个线程访问这些对象,进行有格式和无格式输出是安全的。
[编辑]注解
名称中的 “c” 代表“字符”(stroustrup.com FAQ);clog
表示“字符日志”而 wclog
表示“宽字符日志”。
[编辑]示例
运行此代码
#include <iostream> struct Foo {int n; Foo(){ std::clog<<"构造函数\n";} ~Foo(){ std::clog<<"析构函数\n";}}; Foo f;// 静态对象 int main(){ std::clog<<"main 函数\n";}
输出:
构造函数 main 函数 析构函数
[编辑]参阅
初始化标准流对象 ( std::ios_base 的公开成员类) | |
写入到标准 C 错误流 stderr,无缓冲 (全局对象) | |
写入到标准 C 输出流 stdout (全局对象) | |
与输入流关联的 FILE* 类型表达式 与输出流关联的 FILE* 类型表达式 与错误输出流关联的 FILE* 类型表达式 (宏常量) |