命名空间
变体
操作

std::clog, std::wclog

来自 cppreference.com
< cpp‎ | io
 
 
 
 
定义在头文件 <iostream>
extern std::ostream clog;
(1)
extern std::wostream wclog;
(2)

全局对象 std::clogstd::wclog 控制输出到一个实现定义类型的流缓冲区(从 std::streambuf 派生),与标准 C 输出流 stderr 关联,但与 std::cerr/std::wcerr 不同,这些流不会自动刷新,并且 cout 也不会自动与这些流绑定。

保证这些对象在第一次构造类型为 std::ios_base::Init 的对象期间或之前初始化,并且可以在具有 有序初始化 的静态对象的构造函数和析构函数中使用(只要 <iostream> 在定义对象之前包含)。

除非已发出 std::ios_base::sync_with_stdio(false),否则可以安全地从多个线程并发访问这些对象,以进行格式化和非格式化输出。

[编辑] 备注

名称中的 'c' 代表 "字符" (stroustrup.com 常见问题解答);clog 表示 "字符日志",wclog 表示 "宽字符日志"。

[编辑] 示例

#include <iostream>
 
struct Foo
{
    int n;
    Foo()
    {
        std::clog << "static constructor\n";
    }
    ~Foo()
    {
        std::clog << "static destructor\n";
    }
};
 
Foo f; // static object
 
int main()
{
    std::clog << "main function\n";
}

输出

static constructor
main function
static destructor

[编辑] 另请参阅

初始化标准流对象
(std::ios_base 的公共成员类) [编辑]
写入标准 C 错误流 stderr,无缓冲
(全局对象)[编辑]
写入标准 C 输出流 stdout
(全局对象)[编辑]
与输入流关联的类型为 FILE* 的表达式
与输出流关联的类型为 FILE* 的表达式
与错误输出流关联的类型为 FILE* 的表达式
(宏常量) [编辑]