zoukankan      html  css  js  c++  java
  • winform程序未捕获异常解决方法 EventType clr20r3 P1

    在开发winform程序时,用到多线程,在服务器部署后运行,老是自动关才程序,症状描述如下:

    Windows Server 2003的操作系统上,运行.Net 2.0或者3.5的应用程序时,会发现没有任何反应,到系统的事件查看器里会发现类似EventType clr20r3 P1....P2...PN的错误提示。

    很可能的原因就是:应用程序出现了异常,而.net没有或者无法捕捉该异常,所以导致出现如下情况:

    1.程序自动关闭。

    2.此时去任务管理器中会看到一个DW20.exe的进程,不久会自动消失

    3.到事件查看器里面会发现类似EventType clr20r3 P1....P2...PN的错误提示。

     

    解决方法一:.config文件中<configuration>     <runtime>         <legacyUnhandledExceptionPolicy enabled="true" />     </runtime></configuration>这样,主程序遇到未捕获异常不会强制关闭,但为了程序的稳定性与安全性,应该找出抛异常的地方,将其修改。

    解决方法二:

             用到UnhandledExceptionEventHandler事件,通过这个事件,我们可以截获未捕获异常,并进行处理。

    这个事件的事件参数UnhandledExceptionEventArgs e 有两个属性,一个是ExceptionObject,这个属性返回为截获异常的对象实例。还有一个属性是IsTerminating,这个属性告诉我们这个异常是否会导致应用终止。这里需要说明的是,对于.Net1.1  .Net2.0及以上,情况是不一样的,.Net1.1 只有在主线程中的未捕获异常才会终止应用程序,而.Net2.0及以上版本则是始终终止应用程序。

          在主窗体main下,加         AppDomain.CurrentDomain.UnhandledException +=new UnhandledExceptionEventHandler(UnhandledExceptionEventHandler);

    并编码UnhandledExceptionEventHandler事件,

            static void UnhandledExceptionEventHandler(object sender, UnhandledExceptionEventArgs e)

            {

                try

                {

                    LogHelper.ErrorLog(e.ExceptionObject.ToString());//LogHelper是写日志的类,这里,可以直接写到文件里

                }

                catch

                {

                }

            }

        运行程序,异常捕获,找到了问题所在,对代码进行改写。

    本文结束。

    参考:

    http://www.verydemo.com/demo_c173_i4461.html(重要)

    http://www.cnblogs.com/eaglet/archive/2009/02/17/1392191.html(重要) 

    http://hi.baidu.com/ymwang/blog/item/07b1b20eab9cdde537d12265.html(重要)

  • 相关阅读:
    Centos5.8 安装 ImageMagick 6.8.9-3
    Centos5.8 安装 Redmine
    Apache配置中的ProxyPass 和 ProxyPassReverse
    Centos5.8 安装SVN并配置HTTP访问
    Centos5.8 安装 MySQL5.6.19
    Centos5.8 安装 PHP5.5 和 memcached
    CentOS RHEL 安装 Tomcat 7
    Centos5.8 iptables管理
    在SecureCRT中使用rz和sz传输文件
    在Mac mini上安装 ESXi 5.5
  • 原文地址:https://www.cnblogs.com/leku_cc/p/2974077.html
Copyright © 2011-2022 走看看