要记录错误,我有以下可以调用的代码:
void writeErrorToLog(const LogMessage& message)
{
static std::ofstream logFile(ERROR_LOG_FILEPATH, std::ofstream::out | std::ofstream::trunc);
logFile << message.getLogMessage();
logFile.flush();
}
因此,在程序关闭后,日志文件包含上次运行期间发生的所有错误。这没关系,除非没有发生错误。在没有错误的情况下,日志文件包含最后一个之前运行的错误,因为由于延迟初始化,文件从未打开(使用trunc选项)。有什么方法可以强制静态变量初始化?
答案 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(...)