【问题标题】:First-chance exception with Pantheios万神殿的第一次机会例外
【发布时间】: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


    【解决方案1】:

    First chance exceptions 仅表示抛出异常。这并不意味着您的程序中有错误,只是调试器向您显示正在引发异常,因此您有机会在它传播到调用链之前对其进行检查。如果异常被异常处理程序(例如用于日志记录)捕获,您的应用程序将继续运行,否则调试器会为您提供第二次机会异常通知,通知您应用程序将因未处理的异常而退出。

    如果您不想接收第一次机会异常通知,您可以在调试器中将其关闭。 This link 可能有助于如何在应用程序验证器中关闭异常处理。

    要解决此问题,请在应用程序验证程序中关闭异常测试。为此,请按以下步骤操作:

    1.启动应用程序验证器。

    2.在应用程序下,单击要测试的 GDI+ 程序。

    3.在测试下,展开基础知识。

    4.单击清除例外复选框。

    5.运行您要测试的 GDI+ 程序。

    您还可以配置调试工具,以确保在发生访问冲突时不会在调试工具中遇到断点。

    替代方法(在 MSVS 中关闭异常通知)是通过“Debug->Exceptions...”

    或者,如果可能,请确保首先不会引发异常。您将需要检查异常的性质(例如找不到文件)并修复阻止预期操作的条件。

    鉴于 Application Verifier 的性质/目的,我建议采用后一种方法:AV 告诉您发生了一些不正确的事情,以前可能没问题,但以后可能会导致问题(取决于环境、情况等) .)

    【讨论】:

    • 是的,我把它关掉了,所以现在它不再崩溃了。但是,我的日志中不能包含该消息,因为它太难阅读了。我仍然无法弄清楚如何让它消失..
    • 如何将第一次机会异常消息写入自定义日志?如果您正在捕获所有异常并记录它们,您可以找出具体抛出的异常并忽略它。理想的解决方案仍然是在首先调用CreateFileA 时修复导致异常的条件
    • 没有记录异常,但“20120327-112911.994:无法将消息写入日志文件;给定消息如下:”在消息的开头。
    • 是的,这将是理想的解决方案,但由于我不知道如何解决这个问题(只是按照教程到达我所在的位置),我希望有人可能遇到同样的问题并解决了它:)
    • 这实际上可能是 AppVerifier 中的一个错误:this SO question 有类似的问题,虽然还没有答案,但“异常分析”部分指出句柄的 NULL 值被视为无效。 OTOH the CreateFile documentation 声明可以为句柄传递 NULL 值。作为一种解决方法,在 AppVer 下进行测试时,将您的救助日志文件视为常规文件。
    猜你喜欢
    • 2011-01-02
    • 1970-01-01
    • 1970-01-01
    • 2023-02-03
    • 2010-10-08
    相关资源
    最近更新 更多