gpt4 book ai didi

c++ - Linux。不打印到文件

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

我只是为 HLDS 服务器扩展元模型编写代码模块。我编写了一个简单的实用程序函数,用于以 %LOGNAME%_%DATE%.log 格式写入日志在 Windows 中,该功能运行良好,但在 Linux 中,它创建文件但什么也不写。首先,我尝试搜索相关信息,但没有找到解决方案。我尝试 fflush 文件句柄,将缓冲区设置为 _IONBF 模式,但没有任何帮助。非常感谢您阅读本文并帮助我解决这个问题。

void UTIL_LogToFile(char* szFileName, const char *fmt, ...)
{
va_list argptr;
va_start ( argptr, fmt );
vsnprintf ( g_szLogString, sizeof(g_szLogString), fmt, argptr );
va_end ( argptr );

char* szFilePath = new char[strlen(GlobalVariables::g_szDLLDirPath) + 12 + 30 + 1];
char* szLogFile = get_timestring("_%Y%m%d.log");
sprintf(szFilePath, "%slogs/%s%s", (GlobalVariables::g_szDLLDirPath), szFileName, szLogFile);
FILE* hFile = fopen(szFilePath, "a+");
delete[] szFilePath;
delete[] szLogFile;
if(hFile == NULL)
{
char szError[256];
sprintf(szError, "Error fopen: %s\n", strerror(errno));
SERVER_PRINT(szError);
clearerr(hFile);
return;
}

fprintf(hFile, g_szLogString);
if(ferror(hFile))
{
char szError[256];
sprintf(szError, "Error fprintf: %s\n", strerror(errno));
SERVER_PRINT(szError);
clearerr(hFile);
return;
}
fclose(hFile);

}

最佳答案

您应该只检查 errno 当且仅当 前一个函数失败。

如果之前的调用没有失败,errno 的值是undefined

因此,要正确检查错误,您必须首先检查 fopen 调用是否返回空指针:

FILE* hFile = fopen(szFilePath, "a+");
if (hFile == nullptr)
{
perror(szFilePath);
return;
}

关于c++ - Linux。不打印到文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37321407/

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