在下面的代码中,fputs(...) 在 Windows Server 2008 上运行时会抛出一个断言。我在 Vista 或 XP 机器上没有这个问题。我不知道是什么原因造成的?
断言是: Stream != NULL
它似乎也是随机的,因为有时它似乎成功了......随着日志文件的创建。
有人可以帮忙吗?
void DLog::Log(const char *fmt, ...)
{
va_list varptr;
va_start(varptr, fmt);
int n = ::_vscprintf(fmt, varptr);
char *buf = new char[n + 1];
::vsprintf(buf, fmt, varptr);
va_end(varptr);
if (!m_filename.empty())
{
FILE *f = fopen(m_filename.c_str(), "at");
if (f != NULL)
{
fputs(buf, f);
fputs("\n", f);
fclose(f);
}
else
::MessageBox(0,"Error at fputs in Log","Error",0);
}
delete [] buf;
}