C ++:如何摆脱延迟初始化

时间:2016-01-11 15:12:39

标签: c++ stream lazy-initialization

要记录错误,我有以下可以调用的代码:

void writeErrorToLog(const LogMessage& message)
    {
        static std::ofstream logFile(ERROR_LOG_FILEPATH, std::ofstream::out | std::ofstream::trunc);
        logFile << message.getLogMessage();
        logFile.flush();
    }

因此,在程序关闭后,日志文件包含上次运行期间发生的所有错误。这没关系,除非没有发生错误。在没有错误的情况下,日志文件包含最后一个之前运行的错误,因为由于延迟初始化,文件从未打开(使用trunc选项)。有什么方法可以强制静态变量初始化?

1 个答案:

答案 0 :(得分:1)

这样的事情怎么样:

class Log
{
    private:
       std::ofstream _logFile;
    public:
       Log()
       : _logFile(ERROR_LOG_FILEPATH, std::ofstream::out | std::ofstream::trunc)
       {
       }

       void writeErrorToLog(const LogMessage& message)
       {
           _logFile << message.getLogMessage();
           _logFile.flush();
       }
}

然后你可以使用这个类的单个实例(应用单例模式)。无论何时实例化类,无论是否存在错误,它都将截断文件。

您也可以将_logFile成员设为静态:

class Log
{
    private:
       static std::ofstream _logFile;
    public:
       static void writeErrorToLog(const LogMessage& message)
       {
           _logFile << message.getLogMessage();
           _logFile.flush();
       }
}

// In cpp
std::ofstream Log::_logFile(ERROR_LOG_FILEPATH, std::ofstream::out | std::ofstream::trunc);

这样你就可以像这样访问它:

Log::writeErrorToLog(...)