@H_301_1@使用代码从
this thread挂钩控制台关闭事件,我有时会得到一个没有堆栈跟踪的NullReferenceException(大多数情况下我没有).它发生在发布和调试中,并且“抛出异常时中断”没有帮助(它中断,但堆栈跟踪仍为空).当我正常退出应用程序时,我从未得到此异常(这是命中输入并因此释放Console.ReadLine).应用程序事件日志有2个条目:
@H_301_3@Application: MyApp.exe Framework Version: v4.0.30319 Description:@H_301_3@和:
The process was terminated due to an unhandled exception. Exception
Info: System.NullReferenceException Stack:
@H_301_3@Faulting application name: Gateway.exe,version: 1.0.0.0,time stamp:@H_301_3@Google已经通过SetConsoleCtrlHandler透露了一些bugs和issues,所以我想知道这是否是一场失败的战斗.
0x4e284101 Faulting module name: unknown,version: 0.0.0.0,time
stamp: 0x00000000 Exception code: 0xc0000005 Fault offset: 0x004d41ce
Faulting process id: 0xf00 Faulting application start time:
0x01cc47b827e19a6e Faulting application path:
C:\dev\MyApp.exe Faulting module path:
unknown Report Id: 689c1caa-b3ab-11e0-ba1b-00247e777f12
解决方法
像这样的代码最典型的问题是不保留对委托实例的引用.您作为SetConsoleCtrlHandler()的第一个参数传递的那个.垃圾收集器无法通过非托管代码查看对委托对象的引用.因此,当垃圾收集器运行时,这最终会爆炸:
SetConsoleCtrlHandler(Handler,true);@H_301_3@这与完全相同
SetConsoleCtrlHandler(new EventHandler(Handler),true);@H_301_3@假设您使用了链接代码中的类型.该代码的作者通过使_handler成为静态变量来仔细避免此问题.与前两行代码创建的临时委托实例相反.将其存储在静态变量中可确保它在程序的生命周期内保持引用.在这个特殊情况下要做的事情,因为你实际上对事件感兴趣,直到程序结束.