微笑空间站

对于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:\VSProjects2010\Bingosoft.ProjectDemo\Bingosoft.ProjectDemo\Bingosoft.ProjectDemo.WebApp
\App_Config\SqlCommands\Subway\Subway.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!这次就成功了(这里就不截图了,项目涉及公司内容,抱歉!但我的的确确是运行成功了~~)

 

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

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

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

原创,转载请注明出处 叁半月

 

 

 

posted on 2015-01-12 12:43  xuyongsky1234  阅读(5262)  评论(0编辑  收藏  举报