一、網(wǎng)絡(luò)上的一般說(shuō)法
1、ViewState 對(duì)象為Null。
2、DateSet 空。 3、sql語(yǔ)句或Datebase的原因?qū)е翫ataReader空。 4、聲明字符串變量時(shí)未賦空值就應(yīng)用變量。 5、未用new初始化對(duì)象。 6、Session對(duì)象為空。 7、對(duì)控件賦文本值時(shí),值不存在。 8、使用Request.QueryString()時(shí),所獲取的對(duì)象不存在,或在值為空時(shí)未賦初始值。 9、使用FindControl時(shí),控件不存在卻沒(méi)有做預(yù)處理。 10、重復(fù)定義造成未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例錯(cuò)誤. 二、
(1)所設(shè)置的變量為空值或沒(méi)有取到值,一般出現(xiàn)在傳遞參數(shù)的時(shí)候出現(xiàn)這個(gè)問(wèn)題,也會(huì)在使用DataGrid或gridview或datalist等數(shù)據(jù)控件時(shí)出現(xiàn).
(2)控件名稱(chēng)與codebehind里面的沒(méi)有對(duì)應(yīng)
(3)未用new初始化對(duì)象
(4)在程序中所引用的控件不存在
解決方法:
(1)使用try..catch...finally捕捉錯(cuò)誤,或直接用response.write()輸出所取的變量值
(2)查看代碼中是否存在未初始化的變量
三、
SqlConnection.Open 未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例
在使用VS2003開(kāi)發(fā) ASP.NET程序時(shí)候 有時(shí)候操作 SqlConnection對(duì)象的Open()方法時(shí)候會(huì)出現(xiàn)
未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例。
說(shuō)明: 執(zhí)行當(dāng)前 Web 請(qǐng)求期間,出現(xiàn)未處理的異常。請(qǐng)檢查堆棧跟蹤信息,以了解有關(guān)該錯(cuò)誤以及代碼中導(dǎo)致錯(cuò)誤的出處的詳細(xì)信息。
異常詳細(xì)信息: System.NullReferenceException: 未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例。
源錯(cuò)誤:
。。。。 conn.Open();
......
跟蹤調(diào)試也肯定可以確定 對(duì)conn進(jìn)行new 操作 但是程序經(jīng)常在這個(gè)地方報(bào)錯(cuò),但是有時(shí)候重啟服務(wù)器或者重啟IIS有能正常使用了。 怎么調(diào)試也找不到問(wèn)題 那么這個(gè)時(shí)候可能是 你本機(jī)上安裝的.NET FRAMEEWORK 框架有問(wèn)題,可能沒(méi)有沒(méi)有安裝SP1.1補(bǔ)丁
需要打NET FRAMEEWORK1.1 SP1的補(bǔ)丁,到微軟官方網(wǎng)站下載安裝后就好了。 四、
一般出現(xiàn)NullReferenceException異常的我個(gè)人總結(jié)有以下情況:
1、對(duì)象所在的命名空間沒(méi)有引用 2、對(duì)象沒(méi)有實(shí)例化 3、出現(xiàn)異常,實(shí)例化失敗對(duì)象為 null 五、
IIS 扛不住的時(shí)候,也會(huì)出現(xiàn)上面的錯(cuò)誤。
當(dāng)應(yīng)用程序的用戶(hù)訪(fǎng)問(wèn)量超過(guò)它能承受的范圍之后,就會(huì)出錯(cuò)。 改善你的程序,使用緩存,盡量減少與數(shù)據(jù)庫(kù)交互的次數(shù)。 六、
我碰到的問(wèn)題是,無(wú)意重置了DataSet引用,后出現(xiàn)這個(gè)問(wèn)題,請(qǐng)大家好好查查自己的代碼,是不是在其他地方重新引用了,在我的程序中DataSet被設(shè)置成全局對(duì)象。
七、
當(dāng)你發(fā)現(xiàn)所有的方法不行時(shí),打上.netframework的補(bǔ)丁
八、
我出現(xiàn)這個(gè)錯(cuò)誤,僅僅因?yàn)榫W(wǎng)站里面DAL的dll文件失效,業(yè)務(wù)層實(shí)例化不了IDAL里面的對(duì)象
但也浪費(fèi)了一下午的時(shí)間在調(diào)代碼上 九、
為每個(gè)可疑的地方添加監(jiān)視,起初以為是sql語(yǔ)句寫(xiě)錯(cuò)了,查了幾遍,換用sql語(yǔ)句還是報(bào)同樣的錯(cuò)誤。根據(jù)google出來(lái)的結(jié)果,提到對(duì)象重定義會(huì)引起這樣的結(jié)果。根據(jù)這一提示,替換掉頁(yè)面級(jí)全局對(duì)象,總算搞定了。
class DBOper{ /*構(gòu)造函數(shù)沒(méi)有函數(shù)體 * *c#寫(xiě)的 一系列對(duì)數(shù)據(jù)庫(kù)操作方法 * * } 最初為了省事,盡量少聲明對(duì)象,只在全局聲明了一個(gè)private DBOper db=new DBOper(),在不同方法里面調(diào)用該對(duì)象的方法,以避免為其定義而造成內(nèi)存浪費(fèi)。后來(lái)代碼重構(gòu),在編譯的時(shí)候并未報(bào)錯(cuò)。但是當(dāng)運(yùn)行的時(shí)候,就出現(xiàn)” NullReferenceException: 未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例“。結(jié)果就因它而搞了幾個(gè)小時(shí)。后來(lái)根據(jù)google的結(jié)果,將不同方法中使用到的DBOper對(duì)象一一重定義為局部變量(一個(gè)方法里面只定義一個(gè)DBOper對(duì)象,多次調(diào)用其方法均正常),去掉全局的private變量。再運(yùn)行的時(shí)候就正常了。 至于為什么將自定義的對(duì)象提成為class為private在不同的方法里面使用后而出現(xiàn)這樣的問(wèn)題,現(xiàn)在還不是很清楚......................... 本文來(lái)自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/sollion/archive/2010/07/30/5777475.aspx |
|