乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例--可能出現(xiàn)的問(wèn)題總結(jié)

       狼志凌云 2010-12-27
      一、網(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

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶(hù)發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶(hù) 評(píng)論公約

        類(lèi)似文章 更多