【问题标题】:Examining a managed exception in an unmanaged thread检查非托管线程中的托管异常
【发布时间】:2016-01-26 05:19:14
【问题描述】:

我正在查看一个小型转储文件,其中主线程 (c++) 使用 CLR 启动托管 (C#.NET) 窗口,在托管部分引发异常,并使应用程序崩溃。我一直在寻找技术来检查异常细节以寻找线索,但它们主要用于其中一个(完全非托管的堆栈和线程或完全托管的堆栈和线程)。

托管调用堆栈的部分如下,我可以看到在 .NET 部分中引发了异常,但我不确定有一种方法可以深入查看引发的细节。我在挖掘 .dmp 文件方面还很陌生,因此非常感谢任何指导。

001ddb04 68b92a42 KERNELBASE!RaiseException+0x58
001ddba8 68c655ef clr!RaiseTheExceptionInternalOnly+0x276
001ddbd8 68c6de52 clr!UnwindAndContinueRethrowHelperAfterCatch+0x83
001ddc6c 627528df clr!CEEInfo::resolveToken+0x59b
001ddc7c 62778872 clrjit!Compiler::impResolveToken+0x3a
001de3ac 62751d53 clrjit!Compiler::impImportBlockCode+0x29b3
001de42c 62751f48 clrjit!Compiler::impImportBlock+0x5f
001de444 62753405 clrjit!Compiler::impImport+0x235
001de464 62753635 clrjit!Compiler::compCompile+0x63
001de4a0 62753823 clrjit!Compiler::compCompileHelper+0x2fa
001de518 627536f6 clrjit!Compiler::compCompile+0x213
001de608 6275385f clrjit!jitNativeCode+0x1e3
001de62c 68a74710 clrjit!CILJit::compileMethod+0x25
001de67c 68a747a9 clr!invokeCompileMethodHelper+0x41
001de6bc 68a747eb clr!invokeCompileMethod+0x31
001de720 68a73684 clr!CallCompileMethodWithSEHWrapper+0x2a
001deab8 68a73920 clr!UnsafeJitFunction+0x3ca
001deb94 68a81e5e clr!MethodDesc::MakeJitWorker+0x36b
001dec08 68a550b6 clr!MethodDesc::DoPrestub+0x59d
001dec70 68a44279 clr!PreStubWorker+0xed
001deca0 16c5185a clr!ThePreStub+0x16
001deda4 5ae8f887 0x16c5185a
001dedc0 5ae20c9c MYDLL!CLoader::InvokeCSharpControl

【问题讨论】:

    标签: c# c++ exception windbg crash-dumps


    【解决方案1】:

    0x16c5185a 是 JIT 编译器编译 .NET 代码的内存地址。由于即时编译,没有像 C++ 中那样的符号,您需要不同的工具(WinDbg 的扩展)。

    首先,使用.exr -1 检查它是否是.NET 异常。除少数例外,代码应为0xE0434F4D(ASCII 字符为.COM)。

    如果是这种情况,请加载 SOS 扩展以分析 .NET 详细信息:.loadby sos clr。接下来,运行命令!PrintException(简称!pe)以获取有关异常的详细信息,并运行!ClrStack(与大小写无关)以获取有关.NET 调用堆栈的详细信息。

    如果您have a good crash dump for .NET,可能会有更多详细信息。

    【讨论】:

    • 感谢您提供详细信息。看起来这不是 .NET 异常 - 而是代表 STATUS_FATAL_USER_CALLBACK_EXCEPTION 的异常代码。
    猜你喜欢
    • 2015-09-03
    • 1970-01-01
    • 2014-07-09
    • 1970-01-01
    • 2011-10-14
    • 1970-01-01
    • 2011-12-15
    • 2011-09-01
    • 1970-01-01
    相关资源
    最近更新 更多