gpt4 book ai didi

c++ - 记录器在崩溃后不将记录的信息存储到文件中

转载 作者:太空宇宙 更新时间:2023-11-04 15:27:09 25 4
gpt4 key购买 nike

好吧,如果记录器只在事情进展顺利时才保留记录,那么它有什么用呢?

这是一个非常简单的东西,记录器,我想在扩展它之前测试它:

//记录器.h

class Logger : boost::noncopyable
{
public:
static void write(std::string const& msg, int line, std::string const& file);

private:
Logger();

private:
static std::ofstream m_sOut;
};

#define LOG(msg) Logger::write(msg, __LINE__, __FILE__)

//记录器.cpp

std::ofstream Logger::m_sOut("Logfile");

void Logger::write(const std::string &msg, int line, const std::string &file, Level level /* = Info */)
{
m_sOut << file << ": " << line << ": " << msg << "\n";
}

我担心这太简单了。如果我正常退出程序,它会按预期输出到我的日志文件中。但是,如果发生崩溃,则没有输出。

我必须做什么才能确保它在发生崩溃时输出到日志?

最佳答案

取决于它何时崩溃,我会说。如果它是 日志输出期间,则所有赌注均已关闭。

首先,我会确保在每次调用后刷新日志输出,所以我会在 write 中使用 std::endl 而不是 \n ()。您还必须验证这是否确实足够,或者您是否必须采取额外的步骤来确保您正在使用的流不会缓冲写入。

编辑:正如评论中所指出的,在没有任何类型的缓存/缓冲的情况下直接写入磁盘既缓慢又昂贵。这是一种权衡——如果您绝对必须要求您不能丢失任何日志信息,除非程序在日志语句期间崩溃,您可能必须这样做。我可能会放宽一点要求,只依赖 std::endl 的行为,这会导致流被刷新;这仍然会像操作系统缓冲区一样在流下方留下缓冲区,但您很有可能不会丢失任何日志输出。

关于c++ - 记录器在崩溃后不将记录的信息存储到文件中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5875125/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com