版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
《高級語言程序設(shè)計(jì)》11年4月14日星期四經(jīng)驗(yàn)與技巧─程序調(diào)試11年4月14日星期四???從電腦誕生之日起,就有了電腦Bug。第一個有記載的bug是美國海軍的程序員,編譯器的發(fā)明者格蕾斯·哈珀(GraceHopper)發(fā)現(xiàn)的。1945年9月9日,下午三點(diǎn)。哈珀中尉正領(lǐng)著她的小組構(gòu)造一個稱為“馬克二號”的計(jì)算機(jī)。這還不是一個完全的電子計(jì)算機(jī),它使用了大量的繼電器,一種電子機(jī)械裝置。突然,馬克二型死機(jī)了。技術(shù)人員試了很多辦法,最后定位到第70號繼電器出錯。哈珀觀察這個出錯的繼電器,發(fā)現(xiàn)一只飛蛾躺在中間,已經(jīng)被繼電器打死。她小心地用攝子將蛾子夾出來,用透明膠布帖到“事件記錄本”中,并注明“第一個發(fā)現(xiàn)蟲子的實(shí)例?!睆拇艘院螅藗儗⒂?jì)算機(jī)錯誤戲稱為蟲子(Bug),而把找尋錯誤的工作稱為(Debug)?!癇ug”與“Debug”的來歷
MarkII11年4月14日星期四Bug和Debug?沒有Bug的就不是軟件?核心的問題是:?怎樣在軟件中查出這個Bug??怎樣修正這個Bug??怎樣發(fā)現(xiàn)產(chǎn)生Bug的根源?11年4月14日星期四初學(xué)者的困惑?在錯誤面前一籌莫展?根本就不單步跟蹤程序,或者不敢往下層函數(shù)跟蹤?拼命的單步跟蹤,但卻不知道該關(guān)心什么??總是發(fā)現(xiàn)編譯器的“Bug”?總是編輯并祈禱?隨便的,沒有目的的修改代碼,祈求奇跡的出現(xiàn)11年4月14日星期四軟件開發(fā)的困難?軟件總是需要修改????添加新特性解決bug優(yōu)化重構(gòu)?而修改軟件又是危險的舉動我們?nèi)绾蔚弥呀?jīng)正確的完成了修改?我們?nèi)绾蔚弥獩]有破壞任何(既有的)東西?
? ?11年4月14日星期四Bug的種類?程序設(shè)計(jì)中常見的Bug可以分為三種:?編譯錯誤?運(yùn)行時錯誤?邏輯錯誤11年4月14日星期四編譯錯誤?編譯錯誤是指程序在編譯過 程中出現(xiàn)的錯誤。它是由于 不正確的編寫代碼而產(chǎn)生的 如非法使用或丟失關(guān)鍵字、遺漏了某些必需的標(biāo)點(diǎn)符號、函數(shù)調(diào)用缺少參數(shù)或傳遞了不匹配的參數(shù)等等。inti;intarray[5];fore(i=0;i<=5;i++){array[i]=0;!}11年4月14日星期四?例:數(shù)組下標(biāo)越界是一種典型的運(yùn)行時錯誤
運(yùn)行時錯誤?運(yùn)行時錯誤是指應(yīng)用程序在運(yùn)inti;
行期間執(zhí)行了非法操作或某些intarray[5];
操作失敗,如打開的文件未找 到、磁盤空間不足、網(wǎng)絡(luò)連接for(i=0;i<=5;i++)
斷開、除法中除數(shù)為零等等;{array[i]=0;!}11年4月14日星期四邏輯錯誤?邏輯錯誤是指應(yīng)用程序未按照預(yù)期的方式運(yùn)行時所產(chǎn)生的錯誤。一般來講,這不是屬于語法層次的錯誤,應(yīng)用程序可以執(zhí)行,但是得不到正確的預(yù)期結(jié)果。?例:對于一個數(shù)組的初始化,預(yù)期對其某個特定位置賦初始值,其余置零,那么在這段代碼完成后intarray[100];array[55]=55;for(inti=0;i<100;i++)array[i]=0;
{! }
就沒有得到我們預(yù)期的結(jié)果(代 碼執(zhí)行順序的邏輯錯誤)。11年4月14日星期四Bug的定位?關(guān)注接口?從上層逐漸往下層排查,將斷點(diǎn)設(shè)在上層函數(shù)的入口,單步執(zhí)行跟蹤程序的流程,將搜索的方位逐漸縮小,最后定位在一個函數(shù)內(nèi)部?關(guān)注溢出?C語言的靈活性,指針的應(yīng)用,以及C語法的寬容性很容易造成代碼的錯誤,這其中最主要的就是內(nèi)存單元的溢出,我們需要注意譬如strcpy();scanf();gets()等函數(shù)的目的緩沖區(qū)是否越界?關(guān)注邊界數(shù)組的上限循環(huán)的次數(shù)輸入?yún)?shù)的極限情況(0,空,負(fù)數(shù),最大的情況等等)
? ? ?11年4月14日星期四Bug的修改?別急著改,想想,再想想,想清楚了再動手。?考慮所作的修改可能會對系統(tǒng)造成的新的影響是什么??我的修改會對其他人的代碼造成影響嗎??是否會對全局的數(shù)據(jù)結(jié)構(gòu)或者函數(shù)接口定義作修改?如果是,如何通知所有的其他人??修改完了,應(yīng)該有詳細(xì)的文檔,代碼注釋,并對修改過的代碼進(jìn)行回歸測試11年4月14日星期四Debug過程????代碼檢查(CodeReview)編譯器的警告好的CodingStyle調(diào)試?三種方法???單步調(diào)試測試用例預(yù)定義宏11年4月14日星期四“橡皮鴨程序調(diào)試法”??????1.找一個橡皮鴨子。你可以去借,去偷,去搶,去買,自己制作……反正你要搞到一個橡皮鴨子。2.把這個橡皮鴨子放在你跟前。標(biāo)準(zhǔn)做法是放在你的桌子上,電腦顯示器邊,或是鍵盤邊,反正是你的跟前,面朝你。3.然后,打開你的源代碼。不管是電腦里的還是打印出來的。4.對著那只橡皮鴨子,把你寫下的所有代碼,一行一行地,精心地,向這只橡皮鴨子解釋清楚。記住,這是解釋,你需要解釋出你的想法,思路,觀點(diǎn)。不然,那只能算是表述,而不是解釋。5.當(dāng)你在向這只始終保持沉默的橡皮鴨子解釋的過程中,你會發(fā)現(xiàn)你的想法,觀點(diǎn),或思路和實(shí)際的代碼相偏離了,于是你也就找到了代碼中的bug。6.找到了BUG,一定要記得感謝一下那個橡皮鴨子哦。11年4月14日星期四“橡皮鴨程序調(diào)試法”??為什么這個方法要叫做橡皮鴨呢?因?yàn)橄鹌喿邮俏鞣饺嗽谂菰钑r最喜歡玩的一個小玩具,所以,這個東西應(yīng)該家家戶戶都必備的。因?yàn)?,這個方法由西方人發(fā)明,所以,就被取名為“橡皮鴨”了。你覺得這個方法太“愚蠢”,太“弱智”了?是的,看上去,會這樣做的人腦子好像是有點(diǎn)毛病。不過,我要告訴你的是,這個方法的
確有效。因?yàn)?,這就是“CodeReview”的雛形!
Onceaproblemisdescribedinsufficient detail,itssolutionisobvious. “一旦一個問題被充分地描述了他的細(xì)節(jié),那么解決方法也是 顯而易見的?!?1年4月14日星期四編譯器的警告?Error&Warning?編譯器的警告要認(rèn)真對待?應(yīng)該盡量編寫沒有警告的代碼?除非你確切的知道編譯器為什么產(chǎn)生警告,以及后果?有一個小伙子在一個辦公大樓的門口抽著煙,一個婦女路過他身邊,并對他說:“你知道不知道這個東西會危害你的健康?我是說,你有沒有注意到香煙盒上的那個警告(Warning)?”小伙子說,“沒事兒,我是一個程序員”。11年4月14日星期四?編碼風(fēng)格Thus,programsmustbewrittenforpeopletoread,andonlyincidentallyformachinestoexecute.$$《StructureandInterpretationofComputerPrograms》
縮進(jìn)和空白
?注釋
?命名
?函數(shù)11年4月14日星期四
Debug的方法和工具?一般的Debug工具都提供以下功能:pointandWatchpoint)
?斷點(diǎn)與數(shù)據(jù)觀測點(diǎn)(Break
?單步(Step)
?變量的觀察與修改(Watch)
?現(xiàn)場演示....11年4月14日星期四
Debug的方法和工具?一般的Debug工具都提供以下功能:pointandWatchpoint)
?斷點(diǎn)與數(shù)據(jù)觀測點(diǎn)(Break
?單步(Step)
?變量的觀察與修改(Watch)
?現(xiàn)場演示....11年4月14日星期四快捷鍵1、設(shè)置斷點(diǎn),F(xiàn)9(開關(guān)鍵):可設(shè)置多個,一般在疑點(diǎn)代碼行2、F5(GO)讓程序運(yùn)行到光標(biāo)所在行。 此功能將全速執(zhí)行程序直到遇到一個斷點(diǎn)或程序結(jié)束,或直到程序暫停等待用戶輸入.2、單步跟蹤:F10(stepover)與F11(StepInfo
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度行業(yè)考察參觀者保密合同3篇
- 二零二四年度新聞攝影師聘用合同范本3篇
- 二零二五版櫥柜定制化生產(chǎn)與市場拓展合同3篇
- 2025年度茶葉原料進(jìn)口合同范本4篇
- 二零二四石材外墻干掛工程現(xiàn)場管理及協(xié)調(diào)合同3篇
- 二零二五餐飲配送車輛安全監(jiān)控系統(tǒng)安裝合同3篇
- 二零二四年度營業(yè)員勞動合同:員工申訴與處理3篇
- 二零二五年度廠房投資合作開發(fā)合同4篇
- 2025年度餐飲廚房設(shè)備環(huán)保升級與維修服務(wù)合同4篇
- 2025年度酒店式公寓租賃合同示范文本4篇
- 第1課 隋朝統(tǒng)一與滅亡 課件(26張)2024-2025學(xué)年部編版七年級歷史下冊
- 2025-2030年中國糖醇市場運(yùn)行狀況及投資前景趨勢分析報告
- 【歷史】唐朝建立與“貞觀之治”課件-2024-2025學(xué)年統(tǒng)編版七年級歷史下冊
- 冬日暖陽健康守護(hù)
- 水處理藥劑采購項(xiàng)目技術(shù)方案(技術(shù)方案)
- 2024級高一上期期中測試數(shù)學(xué)試題含答案
- 盾構(gòu)標(biāo)準(zhǔn)化施工手冊
- 天然氣脫硫完整版本
- 山東省2024-2025學(xué)年高三上學(xué)期新高考聯(lián)合質(zhì)量測評10月聯(lián)考英語試題
- 不間斷電源UPS知識培訓(xùn)
- 三年級除法豎式300道題及答案
評論
0/150
提交評論