對於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<?xml version="1.0" encoding="utf-8"?> <configuration> <system.web> </system.web> </configuration> View Code
\App_Config\SqlCommands\Subway\Subway.SqlServer.config'中指出了Subway.SqlServer.config文件必須有一個command值,我們來看下這個文件!
看看項目中相似的一個文件內容:
<?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!這次就成功了(這裡就不截圖了,項目涉及公司內容,抱歉!但我的的確確是運行成功了~~)
好了,今天就寫到這裡~~
由於技術有限,希望大家理解包含,多多指導~~
如果寫的有缺陷不好的,大家評論中指出,我會修改的,謝謝~~