如何使.NET 4抛出ExecutionEngineException?

时间:2013-10-30 00:47:10

标签: .net executionengineexception

我们的应用程序有时会引发ExecutionEngineException。我认为当它发生时,应用程序应该崩溃,但它不会崩溃。即使事件查看器声称应用程序已终止 - 它仍继续运行!只是看起来有问题的线程被静默杀死。

问题是我们无法在发生时重新创建条件 - 在发生异常之前,可疑代码会被执行数千次。日志中没有任何内容。 简而言之 - 我们感到困惑。

我希望能够随意生成此异常,以便了解应用程序在发生时的行为方式。当然,它必须由框架本身抛出,发布throw new ExecutionEngineException不计算。

所以,我的问题是 - 我怎样才能可靠地引起它?请提供代码示例。

我们在.NET 4上,很快就转向.NET 4.5

2 个答案:

答案 0 :(得分:4)

来自MSDN documentation

  

在某些情况下,针对.NET Framework的应用程序可能会   在垃圾回收期间抛出ExecutionEngineException异常   当一个应用程序或运行它的系统在一个   重物。在这种情况下,要解决此问题,您可以禁用   通过修改应用程序来进行并发垃圾收集   配置文件。有关更多信息,请参阅   How to: Disable Concurrent Garbage Collection

如果MSDN文档中建议的解决方法不适合您,则必须根据您对软件的了解进行测试。

现在,创建一个模拟真实应用程序的负载,多线程行为和内存消耗的测试应用程序是一回事 - 将实际软件用作测试软件可能更好(可能会增加一些额外的调试日志+测试代码)。这意味着,遗憾的是这里没有代码示例:(

要使负载测试有意义,您还需要在测试系统上运行这些测试,该测试系统具有与生产系统非常相似(如果不是相同的)硬件/软件配置。只有这样,您才能确定您的ExecutionEngineException是由GC还是由于运行时损坏而导致的。

答案 1 :(得分:1)

除非重现问题(即使必须在生产环境中执行此操作),否则不能轻易导致ExecutionEngineException。 Microsoft具有DebugDiag等实用程序,可以帮助您在发生此类异常时捕获完整的内存转储,

http://blogs.msdn.com/b/chaun/archive/2013/09/15/steps-to-trigger-a-user-dump-of-a-process-with-debugdiag-1-2-when-a-specific-net-exception-is-thrown.aspx

并通过转储分析很容易找到罪魁祸首。不要指望你的日志可以告诉你,因为当这个异常发生时,CLR会崩溃,你的日志也不会那么深。