久久精品电影网_久久久久久电影_久久99精品久久久久久按摩秒播_天堂福利影院_国产男女爽爽爽免费视频_国产美女久久

程序開發中異常的理解及處理異常

所屬欄目:電子技術論文 發布日期:2016-11-17 14:35 熱度:

   程序員在涉及程序的過程中難免會遇到一些異常問題,這些問題對于程序員來說是個不大不小的障礙,也是一種考驗,能否解決這些問題對后續的工作有著關鍵的影響。

軟件和信息服務

  《軟件和信息服務》軟件科技期刊,創刊于1984年,由中國電子信息產業發展研究院、北京中電報發展有限公司主辦。計算機科學技術刊物。旨在推動計算機在我國的應用,推動我國軟件產業的建立和發展,促進軟件應用社會化、軟件開發工程化、軟件成果商品化和軟件經營企業化等方面的工作更好開展。

  異常的工作原理,在有問題的地方產生異常,馬上停止當前的工作,轉向異常處理代碼,如果找不到異常處理代碼,就會見異常向一層匯報,上一層接到異常會做同樣的事,轉向異常處理代碼,或者再將異常向上匯報,這樣逐層間錯誤傳遞出去,直到有一層處理了異常或是一直報告給程序的使用者——用戶。

  這個層就是調用棧,當用戶A運行程序B,B從函數C開始執行,調用函數D,再調用函數E,再調用函數F,這時F出現了異常,那么這個異常的調用棧就是A(棧底)—〉B—〉C—〉D—〉E—〉F(棧頂),這個異常就會沿著這個棧從棧頂開始向棧底的方向報告,如果在函數C中有對這個異常的處理代碼,那么這個異常的報告鏈就是F—〉E—〉D—〉C?梢钥闯,如果在完整的調用棧中沒有處理這個異常的代碼,用戶A就成了異常報告的終點,向windows界面系統,會彈出一個惱人的消息對話框哈。

  那么用戶A向誰報告呢,哈哈,這個已經不屬于程序的范圍了,感覺用會對程序而言好像上帝一樣,訴說痛苦已經讓上帝都聽到了,就心滿意足了哈哈,看來程序真虔誠哈哈。對于異常這個特性,也可以比喻成下屬向上級報告問題,如果下屬知情不報,問題就嚴重了,你要是領導知道下屬是這樣的八成就踢了他,相反如果你有一個報告機制健全的下屬隊伍,哈哈你就威風了。日本企業文蛤中有個宗旨——聯絡,商談,報告,其實就是想讓員工都具有向上級匯報的習慣。現在再看看程序,哈哈,你不用給她們灌輸什么企業文化,不用她們講述什么報告的重要性,她們本身就是忠實報告的,如果把程序員比作企業老總,那么程序就是訓練一隊有素的員工。

  怎樣處理異常。在這里有個原則就是“永遠不要去處理你不知道怎么處理的異常”,

  也就是只處理你知道如何處理的異常,對那些你不知道的異常必須廣開言路,并積極地向上級匯報。什么叫知道如何處理呢?先說一下處理異常有哪些方式,大體有,彈出提示消息框(這個消息框不同于那個惱人的異常報告消息框,她是捕獲異常后,根據處理的具體環境程序員主動編寫的友好的提示消息框),記錄錯誤日志,吞掉,做善后工作等等,那么出現異常時就要站在出現異常的模塊的立場上考慮一下我應該選擇哪種處理方式呢?如果不能做出選擇就選擇不處理,即向上級報告。

  舉個例子,函數Fun1是創建并返回一個活動的數據連接對象的方法,他接受一個數據庫連接字符串,如果調用者(上級)給他一個錯誤的連接字符串,這時Fun1創建不了連接對象,產生了一個創建不了連接對象的異常,那么這時他應該怎樣處理這個異常呢?彈出友好的消息框?說什么友好,Fun1根本就不知道是什么原因使他接收到了錯誤的連接字符串,彈一個“連接字符串有誤”,用戶肯定都有殺你的心,這個提示和用戶的業務邏輯有嘛關系!記錄錯誤日志,這個還行,但是記錄下來的文字無非就是“連接字符串有誤,連接字符串是:SQL……”,好點的話,從連接字符串中看出了問題,一般情況下還得根據代碼上下文去找問題原因。

  這個方式不是不行是不好。吞掉,哈哈開什么玩笑,你既創建不了連接,又不吱一聲,想讓調用者瘋了呀,這個肯定不行。做善后工作,行,確實應該清理一下現場,免得浪費資源,但是還是沒吱一聲,所以這個方式做的不徹底。沒招了,哈,其實上面的分析給我們指明了一條路,幫助我們祛除了錯誤的選擇,這條路就是向上匯報,或是不加任何出來代碼,或是記錄日志,做些善后,再重新將異常拋出。

  那么什么時候就知道怎樣處理異常了,這就得看實際的情況和用戶的要求了,這句話等于沒說,就像其他的標題醒目但給出的結論卻模棱兩可文章一樣,哈哈,這里可以給幾個建議,

  1,一般地,底層模塊或是方法中不要處理異常,

  2,編寫公共模塊、DLL等是,不能采用彈出對話框等依賴于平臺,框架的方式處理異常,

  3,編寫公共模塊、DLL等時,必須在使用文檔中注明每個方法屬性可能拋出的異常。

  4,永遠不要寫 try 這樣的語句。

  { } catch(Exception) { o nothing } 自定義異常。明白了異常的原理和機制后,就可以自己定義異常了,這樣的實踐往往在編寫控件、公共模塊、DLL等的時候,用錯誤編號在網上搜索一下,能找出一大堆關于錯誤代碼的描述。其中大多數是M(icro)S(oft)制定的,MS 從操作系統到各種各樣的框架都有對各種異常的編號,對每種異常做出了詳細的定義,如果你還用過像Spread等商業控件,也可以看到他里邊的各種各樣的異常定義,也就是說我們自己也可以定義異常,在必要的時候,這樣就可以讓自己寫的模塊也加入到訓練有素的員工隊伍中了。至于如何定義異常,具體的編成語言有具體的做法,比如C#中指定一異常一個從Exception繼承來的類,VB中異常是個全局變量等等,參見感興趣語言的語法指南就可以了。

  對異常的重新認識,一直以來許多人都認為異常是非?膳碌,可惡的,她是錯誤的化身,她有惱人的彈出對話框,弄得用戶跟兇煞惡神似的哈哈,其實這些都是誤解,異常一直默默地忠實的報告著程序中出現的嚴重的不可回避的問題,她為了程序、系統的正確性、嚴謹性呼喚你,希望你重視這些問題,希望你用智慧解決這些問題,她是多么的可愛,又是多么的高尚,從來沒有因為對她的誤解而放棄自己的使命……異常很重要,我們更好學會如何去使用她。

文章標題:程序開發中異常的理解及處理異常

轉載請注明來自:http://www.56st48f.cn/fblw/dianxin/dianzijishu/34026.html

相關問題解答

SCI服務

搜論文知識網 冀ICP備15021333號-3

主站蜘蛛池模板: 综合久久亚洲 | 亚洲视频欧美视频 | 国产精品久久久久久二区 | 九色.com | 国产成人区 | 台湾a级理论片在线观看 | 性网站免费 | 国产精品美女在线观看 | 精品日本久久久久久久久久 | 国产我和子的乱视频网站 | 久久这里有精品 | 久久美女网 | 免费的av | 成人午夜视频在线观看 | 在线观看视频一区二区三区 | www.天天干.com | 天天操夜夜操 | 狠狠干网站 | 国产福利在线小视频 | 麻豆av电影网 | 中文精品久久 | 国产精品99久久久精品免费观看 | 欧美一区二区三区国产精品 | 亚洲欧美国产精品久久 | 蜜桃色网| 中文字幕日韩欧美 | 日本一区二区三区四区 | 久久精品国产亚洲a | 精品色| 久久不卡视频 | 9久9久9久女女女九九九一九 | 亚洲国产高清高潮精品美女 | 日韩欧美国产一区二区三区 | www.操com | av手机在线播放 | 91福利在线观看视频 | 国产一区二 | 欧美日本在线 | 亚洲视频一区在线观看 | 国内自拍偷拍视频 | 久久国产精品视频 |