版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
《高級語言程序設計》11年4月14日星期四經驗與技巧─程序調試11年4月14日星期四???從電腦誕生之日起,就有了電腦Bug。第一個有記載的bug是美國海軍的程序員,編譯器的發(fā)明者格蕾斯·哈珀(GraceHopper)發(fā)現的。1945年9月9日,下午三點。哈珀中尉正領著她的小組構造一個稱為“馬克二號”的計算機。這還不是一個完全的電子計算機,它使用了大量的繼電器,一種電子機械裝置。突然,馬克二型死機了。技術人員試了很多辦法,最后定位到第70號繼電器出錯。哈珀觀察這個出錯的繼電器,發(fā)現一只飛蛾躺在中間,已經被繼電器打死。她小心地用攝子將蛾子夾出來,用透明膠布帖到“事件記錄本”中,并注明“第一個發(fā)現蟲子的實例?!睆拇艘院螅藗儗⒂嬎銠C錯誤戲稱為蟲子(Bug),而把找尋錯誤的工作稱為(Debug)?!癇ug”與“Debug”的來歷
MarkII11年4月14日星期四Bug和Debug?沒有Bug的就不是軟件?核心的問題是:?怎樣在軟件中查出這個Bug??怎樣修正這個Bug??怎樣發(fā)現產生Bug的根源?11年4月14日星期四初學者的困惑?在錯誤面前一籌莫展?根本就不單步跟蹤程序,或者不敢往下層函數跟蹤?拼命的單步跟蹤,但卻不知道該關心什么??總是發(fā)現編譯器的“Bug”?總是編輯并祈禱?隨便的,沒有目的的修改代碼,祈求奇跡的出現11年4月14日星期四軟件開發(fā)的困難?軟件總是需要修改????添加新特性解決bug優(yōu)化重構?而修改軟件又是危險的舉動我們如何得知已經正確的完成了修改?我們如何得知沒有破壞任何(既有的)東西?
? ?11年4月14日星期四Bug的種類?程序設計中常見的Bug可以分為三種:?編譯錯誤?運行時錯誤?邏輯錯誤11年4月14日星期四編譯錯誤?編譯錯誤是指程序在編譯過 程中出現的錯誤。它是由于 不正確的編寫代碼而產生的 如非法使用或丟失關鍵字、遺漏了某些必需的標點符號、函數調用缺少參數或傳遞了不匹配的參數等等。inti;intarray[5];fore(i=0;i<=5;i++){array[i]=0;!}11年4月14日星期四?例:數組下標越界是一種典型的運行時錯誤
運行時錯誤?運行時錯誤是指應用程序在運inti;
行期間執(zhí)行了非法操作或某些intarray[5];
操作失敗,如打開的文件未找 到、磁盤空間不足、網絡連接for(i=0;i<=5;i++)
斷開、除法中除數為零等等;{array[i]=0;!}11年4月14日星期四邏輯錯誤?邏輯錯誤是指應用程序未按照預期的方式運行時所產生的錯誤。一般來講,這不是屬于語法層次的錯誤,應用程序可以執(zhí)行,但是得不到正確的預期結果。?例:對于一個數組的初始化,預期對其某個特定位置賦初始值,其余置零,那么在這段代碼完成后intarray[100];array[55]=55;for(inti=0;i<100;i++)array[i]=0;
{! }
就沒有得到我們預期的結果(代 碼執(zhí)行順序的邏輯錯誤)。11年4月14日星期四Bug的定位?關注接口?從上層逐漸往下層排查,將斷點設在上層函數的入口,單步執(zhí)行跟蹤程序的流程,將搜索的方位逐漸縮小,最后定位在一個函數內部?關注溢出?C語言的靈活性,指針的應用,以及C語法的寬容性很容易造成代碼的錯誤,這其中最主要的就是內存單元的溢出,我們需要注意譬如strcpy();scanf();gets()等函數的目的緩沖區(qū)是否越界?關注邊界數組的上限循環(huán)的次數輸入參數的極限情況(0,空,負數,最大的情況等等)
? ? ?11年4月14日星期四Bug的修改?別急著改,想想,再想想,想清楚了再動手。?考慮所作的修改可能會對系統造成的新的影響是什么??我的修改會對其他人的代碼造成影響嗎??是否會對全局的數據結構或者函數接口定義作修改?如果是,如何通知所有的其他人??修改完了,應該有詳細的文檔,代碼注釋,并對修改過的代碼進行回歸測試11年4月14日星期四Debug過程????代碼檢查(CodeReview)編譯器的警告好的CodingStyle調試?三種方法???單步調試測試用例預定義宏11年4月14日星期四“橡皮鴨程序調試法”??????1.找一個橡皮鴨子。你可以去借,去偷,去搶,去買,自己制作……反正你要搞到一個橡皮鴨子。2.把這個橡皮鴨子放在你跟前。標準做法是放在你的桌子上,電腦顯示器邊,或是鍵盤邊,反正是你的跟前,面朝你。3.然后,打開你的源代碼。不管是電腦里的還是打印出來的。4.對著那只橡皮鴨子,把你寫下的所有代碼,一行一行地,精心地,向這只橡皮鴨子解釋清楚。記住,這是解釋,你需要解釋出你的想法,思路,觀點。不然,那只能算是表述,而不是解釋。5.當你在向這只始終保持沉默的橡皮鴨子解釋的過程中,你會發(fā)現你的想法,觀點,或思路和實際的代碼相偏離了,于是你也就找到了代碼中的bug。6.找到了BUG,一定要記得感謝一下那個橡皮鴨子哦。11年4月14日星期四“橡皮鴨程序調試法”??為什么這個方法要叫做橡皮鴨呢?因為橡皮鴨子是西方人在泡澡時最喜歡玩的一個小玩具,所以,這個東西應該家家戶戶都必備的。因為,這個方法由西方人發(fā)明,所以,就被取名為“橡皮鴨”了。你覺得這個方法太“愚蠢”,太“弱智”了?是的,看上去,會這樣做的人腦子好像是有點毛病。不過,我要告訴你的是,這個方法的
確有效。因為,這就是“CodeReview”的雛形!
Onceaproblemisdescribedinsufficient detail,itssolutionisobvious. “一旦一個問題被充分地描述了他的細節(jié),那么解決方法也是 顯而易見的?!?1年4月14日星期四編譯器的警告?Error&Warning?編譯器的警告要認真對待?應該盡量編寫沒有警告的代碼?除非你確切的知道編譯器為什么產生警告,以及后果?有一個小伙子在一個辦公大樓的門口抽著煙,一個婦女路過他身邊,并對他說:“你知道不知道這個東西會危害你的健康?我是說,你有沒有注意到香煙盒上的那個警告(Warning)?”小伙子說,“沒事兒,我是一個程序員”。11年4月14日星期四?編碼風格Thus,programsmustbewrittenforpeopletoread,andonlyincidentallyformachinestoexecute.$$《StructureandInterpretationofComputerPrograms》
縮進和空白
?注釋
?命名
?函數11年4月14日星期四
Debug的方法和工具?一般的Debug工具都提供以下功能:pointandWatchpoint)
?斷點與數據觀測點(Break
?單步(Step)
?變量的觀察與修改(Watch)
?現場演示....11年4月14日星期四
Debug的方法和工具?一般的Debug工具都提供以下功能:pointandWatchpoint)
?斷點與數據觀測點(Break
?單步(Step)
?變量的觀察與修改(Watch)
?現場演示....11年4月14日星期四快捷鍵1、設置斷點,F9(開關鍵):可設置多個,一般在疑點代碼行2、F5(GO)讓程序運行到光標所在行。 此功能將全速執(zhí)行程序直到遇到一個斷點或程序結束,或直到程序暫停等待用戶輸入.2、單步跟蹤:F10(stepover)與F11(StepInfo
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 商洛事業(yè)編面試題及答案
- 醫(yī)院打雜面試題及答案
- 2025年青海物產爆破技術服務有限公司招聘備考題庫帶答案詳解
- 昌吉學院2026年面向社會公開招聘編制外工作人員備考題庫及完整答案詳解1套
- 2025年杭州市丁蘭實驗中學招聘編外校醫(yī)備考題庫及答案詳解一套
- 2025年宜賓市敘州區(qū)婦幼保健計劃生育服務中心第二次公開招聘聘用人員備考題庫及參考答案詳解一套
- 在編護士考試試題及答案
- 碼工管理學考試題及答案
- 2025年安徽藝術職業(yè)學院高層次人才公開招聘10人備考題庫及答案詳解參考
- 2025年巧家縣社會工作協會面向社會公開招聘政府購買社會救助服務人員備考題庫及1套參考答案詳解
- 穿越機入門教學課件
- 《二次根式的混合運算》教學設計
- 地質災害危險性評估方案報告
- 感術行動培訓課件
- DB44∕T 2552-2024 藥物臨床試驗倫理審查規(guī)范
- 血管外科第三集講解
- 跨區(qū)域文化協作-洞察及研究
- 2025 易凱資本中國健康產業(yè)白皮書 -生物制造篇(與茅臺基金聯合發(fā)布)
- 產業(yè)經濟學(蘇東坡版)課后習題及答案
- T/CECS 10227-2022綠色建材評價屋面綠化材料
- 區(qū)域醫(yī)學檢驗中心項目建設方案
評論
0/150
提交評論