对于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; } }
产生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>
看看项目中相似的一个文件内容:
<?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>
原来是在项目中新加个功能模块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>
重新Rebuild下Solution,再次运行本项目,OK!这次就成功了(这里就不截图了,项目涉及公司内容,抱歉!但我的的确确是运行成功了~~)
好了,今天就写到这里~~
由于技术有限,希望大家理解包含,多多指导~~
如果写的有缺陷不好的,大家评论中指出,我会修改的,谢谢~~
原创,转载请注明出处 叁半月