zoukankan      html  css  js  c++  java
  • C#中异常:“The type initializer to throw an exception(类型初始值设定项引发异常)”的简单分析与解决方法

    对于C#中异常:“The type initializer to throw an exception(类型初始值设定项引发异常)”的简单分析,目前本人分析两种情况,如下:

    情况一:

      借鉴麒麟.NET类型初始值设定项引发异常文章!!!写的很详细,大家可以看一看!

    其实麒麟.NET的这篇文章主要讲解分析了静态成员的方面,总的说就是:类型初始化或访问类型的静态成员时,都会对类中的其他静态成员进行初始化,如果有静态构造函数的话,一并执行静态构造函数。在这过程中所引发的异常我就直接借鉴麒麟.NET的例子了:

    class ClassHelper
        {
            public static string Field = Do("Initial the static field");
            public static string StaticString = "Initaial static string";
            public string NonStaticString = "Initial non static string";
            public ClassHelper()
            {
                NonStaticString = "Change non static string in instance constructor";
                StaticString = "Change static string in instance constructor";
            }
            public static string Do(string field)
            {
                Console.WriteLine(field);
                throw new Exception();
                return field;
            }
        }
    View Code

    产生TypeInitializationException的情况归结就是,在静态成员实例化时,只要前后有静态成员实例化时抛出异常,那么整个程序运行时也就会产生如题的“The type initializer to throw an exception(类型初始值设定项引发异常)”异常,这是因为静态成员的性质决定的,具体关于静态,大家可以网上看看!这里不详细描述各种情况的一一举例,推荐的这篇就有详细描述!这里就直接概括一下!

    解决方法:

    既然上面已经指出了抛异常的本质,那么我们就可以一步一步的去追踪异常的产生点了,通过设断点,F11去调试,如果有的看不了,那么具体操作例子看情况二,我遇到的情况及解决。

    情况二:

      具体的内容并没有写,而不是静态成员实例化所直接导致的,我们来一步一步分析与解决。

    运行我的项目是产生异常("Bingosoft.Data.DaoFactory"的类型初始值设定项引发异常)如下:

    网页中抛出的异常信息:

    以上也是我们正常分析所抛出异常的一般步骤,在网页中我们得到了异常源,我们就来分析情况一在此有没有可能???

    这里我项目是在公司开发框架KissU.Net的基础上做的,很多东西都很封闭,我们看不到内部的方法实现,所以我们通过VS去分析相应的dll文件,又抛出的异常信息,我们可以看出是Bingosoft.Data.dll文件中抛出的异常,那么我们就到项目下References中找到Bingosoft.Data.dll,双击打开:

    由网页中抛出的异常信息图中的“异常间接产生点”我们定位于下图位置:

    由此结合网页中的异常信息,我们可以推断出异常的本质还是静态成员实例化是所导致的,但值得注意的是,这只是间接的导致,异常的直接导致原因,我们可以在网页异常信息中看出“InvalidOperationException”已经给了我们提示,所以我们从本质入手。

    解决方法:

    'key' attribute must has a value of command in 'E:VSProjects2010Bingosoft.ProjectDemoBingosoft.ProjectDemoBingosoft.ProjectDemo.WebApp
    App_ConfigSqlCommandsSubwaySubway.SqlServer.config'中指出了Subway.SqlServer.config文件必须有一个command值,我们来看下这个文件!
    <?xml version="1.0" encoding="utf-8"?>
    <configuration>
        <system.web>
    
        </system.web>
    </configuration>
    View Code

    看看项目中相似的一个文件内容:

    <?xml version="1.0" encoding="utf-8" ?>
    <commands xmlns="http://schemas.bingosoft.net/netframework/sqlcommand">
      <!-- 用户信息列表  -->
      <command key="demo.user.list">
        <![CDATA[
          select Id Id,Name Name,LoginId LoginId,Sex Sex,
            (case when Sex = 'M' then '男' when Sex = 'F' then '女' else '' end) SexName,
            Birthday Birthday, OrgId OrgId,  
            (select Name from SEC_Organization where id = su.OrgId) DeptName 
          from Sec_User su
          where 1=1 
          {? AND Name = #UserName# }
          {? AND LoginId = #LoginId#}
            ]]>
      </command>
    ......
    </commands>
    View Code

    原来是在项目中新加个功能模块Subway,结果Subway.SqlServer.config文件并没有配置,那么这个项目框架运行时,把所有被指文件都解析了一遍,自然而然也就解析了这个文件,所以异常也就发生了。本来我是想这个模块不开发的,对整个项目运行是没有影响的,但事实证明这个框架是要把所有的.config都解析的,所以出乎意料的,异常发生了。

    既然知道了,我们就可以着手了,给他添加个空的command,不就行了,再看Subway.SqlServer.config文件

    <?xml version="1.0" encoding="utf-8"?>
    <!--<configuration>
        <system.web>
    
        </system.web>
    </configuration>-->
    <commands xmlns="http://schemas.bingosoft.net/netframework/sqlcommand">
      <command key="example">
        <![CDATA[......]]>
      </command>
    </commands>
    View Code

    重新Rebuild下Solution,再次运行本项目,OK!这次就成功了(这里就不截图了,项目涉及公司内容,抱歉!但我的的确确是运行成功了~~)

    好了,今天就写到这里~~

    由于技术有限,希望大家理解包含,多多指导~~

    如果写的有缺陷不好的,大家评论中指出,我会修改的,谢谢~~

    更多知识分享:微笑空间站

     
  • 相关阅读:
    DIV+CSS列表式布局(同意图片的应用)
    Cache 应用程序数据缓存
    mysql 中 isnull 和 ifnull 判断字段是否为null
    Logo图标快速生成软件(Sothink Logo Maker) v3.5 官方设计师版
    Linqer工具
    mvc学习视频
    MvcPager注意版本与mvc的版本
    此版本的 SQL Server 不支持用户实例登录标志。该连接将关闭“的解决
    ASP.NET 免费开源控件
    逆向知识之CS1.6辅助/外挂专题.1.实现CS1.6主武器副武器无限子弹
  • 原文地址:https://www.cnblogs.com/xuyongsky1234/p/4218131.html
Copyright © 2011-2022 走看看