程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> asp.net運行提示未將對象引用設置到對象的實例錯誤解決方法

asp.net運行提示未將對象引用設置到對象的實例錯誤解決方法

編輯:ASP.NET基礎
未將對象引用設置到對象的實例
一、網絡上的一般說法
1、ViewState對象為Null。
2、DateSet空。
3、sql語句或Datebase的原因導致DataReader空。
4、聲明字符串變量時未賦空值就應用變量。
5、未用new初始化對象。
6、Session對象為空。
7、對控件賦文本值時,值不存在。
8、使用Request.QueryString()時,所獲取的對象不存在,或在值為空時未賦初始值。
9、使用FindControl時,控件不存在卻沒有做預處理。
10、重復定義造成未將對象引用設置到對象的實例錯誤.
二、
(1)所設置的變量為空值或沒有取到值,一般出現在傳遞參數的時候出現這個問題,也會在使用DataGrid或gridview或datalist等數據控件時出現.
(2)控件名稱與codebehind裡面的沒有對應
(3)未用new初始化對象
(4)在程序中所引用的控件不存在
解決方法:
(1)使用try..catch...finally捕捉錯誤,或直接用response.write()輸出所取的變量值
(2)查看代碼中是否存在未初始化的變量
三、SqlConnection.Open未將對象引用設置到對象的實例
在使用VS2003開發ASP.NET程序時候有時候操作SqlConnection對象的Open()方法時候會出現
未將對象引用設置到對象的實例。
說明:執行當前Web請求期間,出現未處理的異常。請檢查堆棧跟蹤信息,以了解有關該錯誤以及代碼中導致錯誤的出處的詳細信息。
異常詳細信息:System.NullReferenceException:未將對象引用設置到對象的實例。
源錯誤:
。。。。
conn.Open();
......
跟蹤調試也肯定可以確定對conn進行new操作但是程序經常在這個地方報錯,但是有時候重啟服務器或者重啟IIS有能正常使用了。怎麼調試也找不到問題那麼這個時候可能是你本機上安裝的.NETFRAMEEWORK框架有問題,可能沒有沒有安裝SP1.1補丁
需要打NET轉載自百分網http://www.oh100.com,請保留此標記FRAMEEWORK1.1SP1的補丁,到微軟官方網站下載安裝後就好了。
四、一般出現NullReferenceException異常的我個人總結有以下情況:
1、對象所在的命名空間沒有引用
2、對象沒有實例化
3、出現異常,實例化失敗對象為null
五、IIS扛不住的時候,也會出現上面的錯誤。
當應用程序的用戶訪問量超過它能承受的范圍之後,就會出錯。
改善你的程序,使用緩存,盡量減少與數據庫交互的次數。
六、我碰到的問題是,無意重置了DataSet引用,後出現這個問題,請大家好好查查自己的代碼,是不是在其他地方重新引用了,在我的程序中DataSet被設置成全局對象。
七、當你發現所有的方法不行時,打上.netframework的補丁
八、我出現這個錯誤,僅僅因為網站裡面DAL的dll文件失效,業務層實例化不了IDAL裡面的對象
但也浪費了一下午的時間在調代碼上
九、
為每個可疑的地方添加監視,起初以為是sql語句寫錯了,查了幾遍,換用sql語句還是報同樣的錯誤。根據google出來的結果,提到對象重定義會引起這樣的結果。根據這一提示,替換掉頁面級全局對象,總算搞定了。
classDBOper{
/*構造函數沒有函數體
**c#寫的一系列對數據庫操作方法
**}最初為了省事,盡量少聲明對象,只在全局聲明了一個privateDBOperdb=newDBOper(),在不同方法裡面調用該對象的方法,以避免為其定義而造成內存浪費。後來代碼重構,在編譯的時候並未報錯。但是當運行的時候,就出現"NullReferenceException:未將對象引用設置到對象的實例"。結果就因它而搞了幾個小時。後來根據google的結果,將不同方法中使用到的DBOper對象一一重定義為局部變量(一個方法裡面只定義一個DBOper對象,多次調用其方法均正常),去掉全局的private變量。再運行的時候就正常了。
至於為什麼將自定義的對象提成為class為private在不同的方法裡面使用後而出現這樣的問題,現在還不是很清楚
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved