【发布时间】:2012-04-22 23:00:06
【问题描述】:
在我尝试使用应用程序验证程序对其进行调试之前,我的应用程序运行良好。之后我开始收到“第一次机会异常...:指定了无效句柄”,问题似乎出在 Pantheios 的“bailout.c”文件中:
hFile = CreateFileA("logging-bailout.txt"
, GENERIC_WRITE
, 0
, NULL
, OPEN_ALWAYS
, 0
, NULL); <--- this is where it crashes, line 442
还有消息:
First-chance exception at 0x7769f8cd in myapp.exe: 0xC0000008: An invalid handle was specified.
=======================================
VERIFIER STOP 0000000000000300: pid 0x3814: Invalid handle exception for current stack trace.
00000000C0000008 : Exception code.
00000000111DE950 : Exception record. Use .exr to display it.
00000000111DE460 : Context record. Use .cxr to display it.
0000000000000000 : Not used.
=======================================
This verifier stop is continuable.
After debugging it use `go' to continue.
=======================================
在控制台只记录我在 Pantheios 中遇到的异常之前,我并没有太在意。但是,现在当应用程序在第一次使用 Pantheios 进行日志记录时崩溃时,我该处理这个问题了,但我不太确定如何处理。
我在设置我的 Pantheios 时遵循本指南:http://www.codeproject.com/Articles/27119/Using-Callback-Back-ends-with-the-Pantheios-Loggin
在我记录的每个文件中,源文件中都有以下几行:
#include <pantheios/pantheios.hpp>
#include <pantheios/inserters/boolean.hpp>
#include <pantheios/inserters/integer.hpp>
#include <Shared/logs.h>
logs.h 包含:
#include <pantheios/implicit_link/core.h>
#include <pantheios/implicit_link/fe.simple.h>
#include <pantheios/implicit_link/be.WindowsConsole.h>
在进行任何日志记录之前,我还会致电 pantheios::init();。
我正在使用 Visual Studio 2010,并且在“其他依赖项”下包含以下 lib 文件:
$(PANTHEIOS_ROOT)\lib\pantheios.1.core.vc10.mt.debug.lib
$(PANTHEIOS_ROOT)\lib\pantheios.1.be.WindowsConsole.vc10.mt.debug.lib
$(PANTHEIOS_ROOT)\lib\pantheios.1.fe.simple.vc10.mt.debug.lib
$(PANTHEIOS_ROOT)\lib\pantheios.1.util.vc10.mt.debug.lib
但是,我所有的日志记录都是这样的:
myapp.exe 中 0x750bb9bc 的第一次机会异常:Microsoft C++ 异常:stlsoft::winstl_project::windows_exception 在内存位置 0x1822bda0..
20120423-104817.497:无法将消息写入日志文件;给定消息如下:[myapp.Qt.Framework.13424, 23/04/2012 10:48:17.496 a.m.;调试]:“一些日志记录”
拨打pantheios::log(pantheios::debug, "some logging");时
然后,我的所有日志记录都会写入项目所在文件夹中的“救助”文件中。这以前有效,但它在我的“待办事项列表”中是一个重要的子弹(但比其他事情更进一步)。
所以现在我的问题是,我该如何解决这个问题?遵循我能找到的每个教程,但没有成功。为什么我的应用在运行 Ms Application Verifier 后决定不再接受这个?没有意义。
【问题讨论】:
标签: c++ visual-studio-2010 pantheios