我们的应用程序有时会引发ExecutionEngineException
。我认为当它发生时,应用程序应该崩溃,但它不会崩溃。即使事件查看器声称应用程序已终止 - 它仍继续运行!只是看起来有问题的线程被静默杀死。
问题是我们无法在发生时重新创建条件 - 在发生异常之前,可疑代码会被执行数千次。日志中没有任何内容。 简而言之 - 我们感到困惑。
我希望能够随意生成此异常,以便了解应用程序在发生时的行为方式。当然,它必须由框架本身抛出,发布throw new ExecutionEngineException
不计算。
所以,我的问题是 - 我怎样才能可靠地引起它?请提供代码示例。
我们在.NET 4上,很快就转向.NET 4.5
答案 0 :(得分:4)
在某些情况下,针对.NET Framework的应用程序可能会 在垃圾回收期间抛出ExecutionEngineException异常 当一个应用程序或运行它的系统在一个 重物。在这种情况下,要解决此问题,您可以禁用 通过修改应用程序来进行并发垃圾收集 配置文件。有关更多信息,请参阅 How to: Disable Concurrent Garbage Collection
如果MSDN文档中建议的解决方法不适合您,则必须根据您对软件的了解进行测试。
现在,创建一个模拟真实应用程序的负载,多线程行为和内存消耗的测试应用程序是一回事 - 将实际软件用作测试软件可能更好(可能会增加一些额外的调试日志+测试代码)。这意味着,遗憾的是这里没有代码示例:(
要使负载测试有意义,您还需要在测试系统上运行这些测试,该测试系统具有与生产系统非常相似(如果不是相同的)硬件/软件配置。只有这样,您才能确定您的ExecutionEngineException是由GC还是由于运行时损坏而导致的。
答案 1 :(得分:1)
除非重现问题(即使必须在生产环境中执行此操作),否则不能轻易导致ExecutionEngineException。 Microsoft具有DebugDiag等实用程序,可以帮助您在发生此类异常时捕获完整的内存转储,
并通过转储分析很容易找到罪魁祸首。不要指望你的日志可以告诉你,因为当这个异常发生时,CLR会崩溃,你的日志也不会那么深。