gpt4 book ai didi

c# - 如何在我的应用程序中找到 StackOverflowException 的来源

转载 作者:可可西里 更新时间:2023-11-01 03:01:16 25 4
gpt4 key购买 nike

我的应用程序中某处出现了 StackOverFlow - 我正试图找到追踪它的方法。

我的事件日志每天都会显示一次崩溃,并包含以下信息:

Faulting application name: MyApp.exe, version: 1.0.0.0, time stamp: 0x522e8317

Faulting module name: clr.dll, version: 4.0.30319.18047, time stamp: 0x515530ce

Exception code: 0xc00000fd

Fault offset: 0x000000000000c657

Faulting process id: 0x117fc

Faulting application start time: 0x01ceadf607b184d2

Faulting application path: C:\Users\Administrator\Desktop\MyApp.exe

Faulting module path: C:\Windows\Microsoft.NET\Framework64\v4.0.30319\clr.dll

Report Id: d52424aa-1a16-11e3-bc4b-002590a4ec55

我读到 0xc00000fd 是一个堆栈溢出,但我不确定它可能发生在哪里(非常大的代码库),以及如何追踪它。有什么想法吗?

最佳答案

这通常是我使用 WinDbg 追踪的东西,否则它只是一个猜谜游戏。下面是一个快速演练,可以让您朝着正确的方向前进。

WinDbg 是 Windows 的调试器,适用于调试托管和非托管代码。它也非常适合检查故障转储。让我们从示例程序开始。

class Program
{
static void Main(string[] args)
{
IWillStackOverflow(0);
}

[MethodImpl(MethodImplOptions.NoInlining | MethodImplOptions.NoOptimization)]
static int IWillStackOverflow(int i)
{
return IWillStackOverflow(i + 1);
}
}

这是一个非常人为的例子,但让我们开始吧。它确实堆栈溢出,也不提供堆栈跟踪。这就是 WinDbg 的用武之地。首先您需要安装它,它是 Windows SDK 中调试工具的一部分。 .有两个版本,x64 和 x86。您需要运行与您的应用程序的位数匹配的那个。

在 WinDbg 中,使用 File -> Open Executable 并运行附加了 WinDbg 的可执行文件。调试器将在您的应用程序加载后立即中断,您可以使用 g 命令转到并使用您的应用程序,直到出现 StackOverflowException。不过,在你这样做之前,请确保你的符号是正确的——通常运行 .symfix+ 会更正它,然后你就可以走了。

当您收到 StackOverflowException 时,调试器将在引发异常的线程上中断,消息将如下所示:

(cc0.b00): Stack overflow - code c00000fd (first chance)

现在我们可以使用此命令加载托管调试扩展(我假设您在这里使用的是 .NET Framework 4.0 或 4.5):

.loadby sos clr

并调用 !clrstack。在这个例子中,输出是:

000000d440c76040 00007ffb282b0111 StackOverflower.Program.IWillStackOverflow(Int32) [Program.cs @ 20]
000000d440c76080 00007ffb282b0111 StackOverflower.Program.IWillStackOverflow(Int32) [Program.cs @ 20]
000000d440c760c0 00007ffb282b0111 StackOverflower.Program.IWillStackOverflow(Int32) [Program.cs @ 20]
..Repeat thousands of times..

所以我们在发生 StackOverflowException 时拥有我们的托管堆栈。

如果您的应用程序不太容易 StackOverflow,您可以配置 ADPlus在发生 StackOverflowException 时获取应用程序的内存转储。 ADPlus 是另一个强大的工具,但它很有效。首先你需要一个 ADPlus 的配置,这里是一个例子:

<ADPlus> 
<!-- Add log entry, log faulting thread stack and dump full on first chance StackOverflow -->
<Exceptions>
<Config>
<!-- Use sov for stack overflow exception -->
<Code> sov </Code>
<Actions1> Log;Stack;FullDump </Actions1>
<!-- Depending on what you intend - either stop the debugger (Q or QQ) or continue unhandled (GN) -->
<ReturnAction1> GN </ReturnAction1>
< Config>
</Exceptions>
</ADPlus>

此配置示例最初由用户 jaskis 在 MSDN 论坛上发布:http://blogs.msdn.com/b/jaskis/archive/2010/08/11/cwa-ends-up-with-blank-screen-on-browser-on-iis-7.aspx然后使用命令行启动带有配置的应用程序。


这只是一个例子,WinDbg 是一个非常强大的工具,尽管它有一点学习曲线。互联网上有很多很好的资源可以帮助你掌握它。 Tess Ferrandez她的博客中有许多文章介绍了 WinDbg 和托管调试扩展。

关于c# - 如何在我的应用程序中找到 StackOverflowException 的来源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18721841/

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