我正在读取一个由某些安装程序进程连续写入的日志文件。但是,在某些情况下,我会因以下原因而随机崩溃:
Crash reason: EXCEPTION_ACCESS_VIOLATION_READ
我有几个关于此的问题-
1:如果您看到以下代码,我正在尝试处理读取时发生的任何异常。那么为什么 EXCEPTION_ACCESS_VIOLATION_READ 没有被捕获并且程序崩溃了。
2:看起来它正在发生,因为安装程序在我读取文件的同时写入文件。 wxTextFile 不允许我打开文件的模式。那么,如果我使用一些 C 函数并以 READ_ONLY 模式打开文件,还会发生此崩溃吗?
以下是我的代码:
wxTextFile file( wxT("C:\\logfile.log") );
WriteLog(wxT("Will start monitoring log file."));
while(true)
{
if(file.Exists())
{
try
{
if(file.Open())
{
wxString str = file.GetLastLine();
WriteLog(wxT("Got::")+str);
file.Close();
}
}
catch(...)
{
WriteLog(wxT("CRASH: something went wrong::MonitorLogFile()"));
}
}
//Exit if needed
Sleep(1500);
}
最佳答案
我相信 14 天后您的问题就会得到解决,不是吗?
我有一种感觉(我对 wxWidgets 知之甚少),你的编译器正在这里执行地址添加
wxT("得到::")+str
尝试将其更改为 2 个真实字符串
wxT() 是解析为 L""的宏调用吗?如果是这样,那么您遇到了问题,您应该修改代码以使用真正的字符串对象(而不是宏文本)+第二个字符串对象执行字符串连接,此时您使用 + 作为运算符重载而不是我怀疑的地址总和
问候
关于c++ - 监视日志文件时崩溃 (C++),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23383291/