在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Bug調(diào)試經(jīng)驗總結(jié)

傳感器技術(shù) ? 來源:EDN電子技術(shù)設(shè)計 ? 作者:EDN電子技術(shù)設(shè)計 ? 2021-05-10 14:17 ? 次閱讀

這十年來我做過小的嵌入式系統(tǒng),大的電信系統(tǒng)以及基于web的系統(tǒng)。使用過C ++,Ruby,JavaPython等。這篇文章中的經(jīng)驗教訓(xùn)旨在幫助減少編碼,測試和調(diào)試三個階段的bug。

下面這些都是我經(jīng)歷過的會導(dǎo)致難點bug的問題:

1.事件順序。在處理事件時,提出下列問題會很有成效:事件可以以不同的順序到達嗎?如果我們沒有接收到此事件會怎么樣?如果此事件接連發(fā)生兩次會怎么樣?哪怕通常不會發(fā)生,但系統(tǒng)(或交互系統(tǒng))其他部分的bug可能會導(dǎo)致事件發(fā)生呢。

2.過早。這是第一點“事件順序”的一個特例,但它確實會引起一些棘手的bug,因此我把它單獨拎出來說明。例如,如果信令消息在配置和啟動程序完成之前就被過早接收,那么可能就會有很多奇怪的行為發(fā)生。另一個例子:連接在被放進空閑列表之前就被標(biāo)記為down。在調(diào)試這類問題時,我們總是假定在空閑列表中的時候連接被設(shè)置為down(但當(dāng)時為什么不把它放到列表外面呢?)。這是我們思考的不足,沒有考慮到有時候事情會過早發(fā)生。

3.悄無聲息的故障。一些最難跟蹤的bug有部分是由那些靜靜失敗并擴展而不是拋出錯誤的代碼所導(dǎo)致的。例如,沒有檢查代碼卻返回錯誤的系統(tǒng)調(diào)用(如bind)。又如:解析代碼在它遇到錯誤元素的時候只是返回而非拋出錯誤。在錯誤狀態(tài)中持續(xù)了一段時間的調(diào)用,會使調(diào)試變得更難。最好一旦檢測到故障就返回錯誤。

4.If。有若干條件的if語句,if (a 或 b) ,特別是當(dāng)有鏈接的時候, if (x) else if (y),都給我引發(fā)了很多bug。即使if語句在概念上很簡單,但當(dāng)有多個條件要跟蹤的時候依然很容易出錯。這些天,我嘗試重寫代碼使之更簡單,以避免處理復(fù)雜的if語句。

5.Else。有一些bug是因為沒有正確考慮到如果條件為false時會發(fā)生什么而引起的。幾乎在所有的情況下,都應(yīng)該有一個else部分來應(yīng)對每一條if語句。此外,如果你在if語句的分支中設(shè)置變量,那么或許你在另一個分支中也要設(shè)置。與此種情況相關(guān)的是標(biāo)記被設(shè)置的情況。只添加用于設(shè)置的標(biāo)記的條件不難,但是很容易忘了添加當(dāng)標(biāo)記應(yīng)該再次重置時的條件。留下一個永遠設(shè)置的標(biāo)志可能會導(dǎo)致之后接連不斷的bug。

6.改變假設(shè)。許多一開始最難預(yù)防的bug是因為改變了假設(shè)所造成的。例如,在開始時,可能每天只有一個客戶事件。于是很多代碼是在這樣的假設(shè)下寫下的。但是后來,設(shè)計改變了,允許每天有多個客戶事件了。發(fā)生這種情況時,很難改變新設(shè)計影響到的所有情況。找到關(guān)于改變的所有顯式依賴關(guān)系不難,難的是要找到所有隱性依賴于舊的設(shè)計的情況。例如,可能會有獲取給定某一天所有客戶事件的代碼。其中的隱含假設(shè)是結(jié)果集永遠不會超過客戶的數(shù)量。關(guān)于這方面的問題我也沒有很好的策略方法,如果各位有的話,還請不吝賜教。

7.日志記錄。可視化程序做什么至關(guān)重要,特別是當(dāng)邏輯很復(fù)雜的時候。確保補充足夠多的(但不要太多)日志記錄,這樣你就可以說明為什么程序要這么做。如果一切正常,那也沒關(guān)系,但要是有問題發(fā)生,你會很慶幸自己添加了這些日志。

測試

作為一個開發(fā)人員,直到要測試了我才會去處理功能。至少,這意味著每一行新的或改變了的代碼行至少已經(jīng)被執(zhí)行過一次。此外,單元測試和功能測試都很不錯,但還不夠。新的功能也必須進行測試,并在類似于產(chǎn)品的環(huán)境中探索。只有這樣,我才能說我完成了一個功能。下面是我經(jīng)歷過的bug所教會我的關(guān)于測試的一些重要的經(jīng)驗教訓(xùn):

1.零和null。如果可行的話,確保總是用零和null來測試。對于字符串,這意味著要測試長度為零的字符串以及字符串為null兩種情況。又如:測試TCP連接的斷開,要在發(fā)送數(shù)據(jù)給它發(fā)送之前。不使用這些組合方法測試是導(dǎo)致bug出現(xiàn)的首位原因。

2.添加和刪除。通常,新的功能包括能夠添加新的配置到系統(tǒng)中——例如,一個用于手機號碼轉(zhuǎn)換的新的配置文件。測試它能否添加新的配置文件是很自然的。但是,我發(fā)現(xiàn)我們很容易忘記去測試刪除配置文件是不是同樣ok。

3.錯誤處理。處理錯誤的代碼往往是難以測試的。最好有能檢查錯誤處理代碼的自動測試,但有時這是不可能的。我有時會使用的一招是臨時修改代碼,使得錯誤處理代碼運行起來。要做到這一點最簡單的方法是反轉(zhuǎn)if語句——例如,從if error_count > 0改成error_count == 0。另一個例子是拼錯數(shù)據(jù)庫列名,從而導(dǎo)致期望的錯誤處理代碼運行。

4.隨機輸入。通常,揭露bug測試的一種測試方法是使用隨機輸入。例如,H.323協(xié)議的ASN.1解碼使用二進制數(shù)據(jù)操作。通過發(fā)送隨機字節(jié)去解碼,我們發(fā)現(xiàn)了解碼器中的幾個bug。另一個例子是用測試呼叫來生成腳本,此時呼叫持續(xù)時間,接聽延遲,第一方掛斷等等都是隨機生成的。這些測試腳本會暴露許多bug,特別是一起發(fā)生的事件會產(chǎn)生并攏干擾。

5.檢查不應(yīng)該發(fā)生的動作。通常測試包括檢查期望動作是不是發(fā)生了。但我們很容易忽視相反的情況——忘記檢查不應(yīng)該發(fā)生的動作是不是的確沒有發(fā)生。

6.擁有工具。我創(chuàng)建了自己的小工具,以使得測試更加簡單。例如,當(dāng)我用VoIP SIP協(xié)議工作時,我寫了一個能夠用正是我想要的標(biāo)題和值回復(fù)的小腳本。這個工具使得測試很多邊界情況變得容易起來。另一個例子是可以進行API調(diào)用的一個命令行工具。通過啟動逐漸添加所需小功能,我得到了一些非常有用的工具。自己寫工具的好處是,我得到的正是我想要的。

在測試中發(fā)現(xiàn)所有的bug,那絕對是不可能的。有一個案例中,我更改了數(shù)字相關(guān)性的處理,數(shù)字由兩個部分組成:路由地址前綴(通常是不變的),以及從000到999動態(tài)分配的數(shù)字。問題在于當(dāng)找到相關(guān)性時,動態(tài)分配的數(shù)字的第一個數(shù)字會在呈現(xiàn)在表格中之前遭到誤刪。也就是說637變成了37。這意味著,到100之前它都是可以工作的,因此,前面100個電話是正常的,但是接下來的900個都是失敗。所以,除非我在重新啟動之前能夠測試超過100次(事實是我沒有),否則我在測試時就不會發(fā)現(xiàn)這個問題。

調(diào)試

1.討論。幫助我最多的調(diào)試技術(shù)是與同事討論問題。通常情況下,只是和同事說明問題,就會讓我意識到問題的癥結(jié)。此外,即使他們不是很熟悉有問題的代碼,他們也往往能提出一些好點子。與同事討論在處理最難的bug時特別有效。

2.密切關(guān)注。通常,如果調(diào)試問題花了很長時間,往往是因為我做了錯誤的假設(shè)。例如,我認為問題發(fā)生在某一方法中,但事實卻是它甚至從來沒有到達那個方法。或者,被拋出的異常不是我以為的那個。或者,我認為軟件的最新版本上正在運行,但其實是一個舊版本。因此,一定要核實細節(jié),而不是假設(shè)。人們更容易看到自己希望看到的東西,而不是事實。

3.最近的變化。當(dāng)曾經(jīng)可以正常工作的東西停止工作,那么這通常是因為最近改變的東西所導(dǎo)致的。在一個案例中,最近的改變只是日志記錄,但是日志中的錯誤卻導(dǎo)致了一個更大的問題。為了更容易找到這種回歸,承認不同的提交會導(dǎo)致不同的變化,以及清楚說明這些更改會有所裨益。

4.相信用戶。有時,當(dāng)用戶報告問題的時候,我的本能反應(yīng)是,“這是不可能的。一定是他們做錯了什么事”。但我學(xué)會了不再用這種方式去回應(yīng)。更多的時間,事實往往證明,他們所報告的的確是實際發(fā)生的情況。因此,這些天,我開始接受他們所報告的內(nèi)容的表明價值。當(dāng)然,我依然會仔細檢查一切是否被正確地設(shè)置等等。我見過很多這樣的情況,讓我明白,因為不尋常的配置或意料之外的用法而導(dǎo)致不可思議的事情的發(fā)生,而我默認的假設(shè)是,他們是正確的,程序是錯誤的。

5.測試修復(fù)。如果bug修復(fù)已準(zhǔn)備就緒,那就必須進行測試。首先在修復(fù)前運行代碼,并觀察該bug。然后應(yīng)用修復(fù)并重復(fù)測試案例。到此為止錯誤行為應(yīng)消失。遵循這些步驟可以確保它確實是一個bug,并且此次修復(fù)的確可以解決這個問題。簡單而有必要。

其他觀察結(jié)果

現(xiàn)在工作于C++時所遇到的幾類bug已經(jīng)完全消失,像堆棧溢出,內(nèi)存損壞,字符串問題和某種形式的內(nèi)存泄漏。

其他問題,如循環(huán)錯誤和邊界情況,我看到的要少得多。但是,這并不意味著那里沒有bug。如果大家有什么有用的預(yù)防和發(fā)現(xiàn)bug的技術(shù)方法,歡迎留言。

作為過來人,最后還想說幾句心靈雞湯:

1、分享第一條經(jīng)驗:“學(xué)歷代表過去、能力代表現(xiàn)在、學(xué)習(xí)力代表未來。”

2、一定要確定自己的發(fā)展方向,并為此目的制定可行的計劃。

3、軟件開發(fā)團隊中,技術(shù)不是萬能的,但沒有技術(shù)是萬萬不能的!

4、詳細制定自己軟件開發(fā)專業(yè)知識學(xué)習(xí)計劃,并注意及時修正和調(diào)整(軟件開發(fā)技術(shù)變化實在太快)。

5、書籍是人類進步的階梯,對軟件開發(fā)人員尤其如此。

6、不要僅局限于對某項技術(shù)的表面使用上,哪怕你只是偶爾用一、二次。

7、在一種語言上編程,但別為其束縛了思想。“代碼大全”中說:“深入一門語言編程,不要浮于表面”。

8、養(yǎng)成總結(jié)與反思的習(xí)慣,并有意識地提煉日常工作成果,形成自己的個人源碼庫、解決某類問題的通用系統(tǒng)體系結(jié)構(gòu)、甚至進化為框架。

9、理論與實踐并重,內(nèi)外雙修。

10、心態(tài)有多開放,視野就有多開闊。

11、盡量參加開源項目的開發(fā)、或者與朋友共同研制一些自己的產(chǎn)品,千萬不要因為沒有錢賺而不做。

12、書到用時方恨少,不要將自己的知識面僅僅局限于技術(shù)方面。

總結(jié)與反思:

(a)不要去做技術(shù)上的高手,除非你的目標(biāo)如此。

(b)提高軟件知識和技術(shù)只是問題的表面,本質(zhì)是要提高自己認識問題、分析問題、解決問題的思想高度。軟件專業(yè)知識的很多方法和原理,可以很容易地延伸、應(yīng)用到生活的其它方面。

(c)在能勝任工作的基礎(chǔ)上,立即去涉獵其它領(lǐng)域的專業(yè)知識,豐富自己的知識體系、提高自己的綜合素質(zhì),尤其是那些目標(biāo)不在技術(shù)方面的朋友。

責(zé)任編輯:lq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 解碼器
    +關(guān)注

    關(guān)注

    9

    文章

    1164

    瀏覽量

    41728
  • 嵌入式
    +關(guān)注

    關(guān)注

    5142

    文章

    19561

    瀏覽量

    315403
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1398

    瀏覽量

    80456

原文標(biāo)題:嵌入式大牛10年調(diào)Bug經(jīng)驗總結(jié)

文章出處:【微信號:WW_CGQJS,微信公眾號:傳感器技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    簡述電源設(shè)計經(jīng)驗技巧

    在電源設(shè)計領(lǐng)域中,經(jīng)驗的積累往往決定了產(chǎn)品的穩(wěn)定性和可靠性。若是電子新人了解到一些實用的設(shè)計技巧,電源設(shè)計將事半功倍。下面將總結(jié)大佬的14條電源設(shè)計經(jīng)驗,以此提供參考和指導(dǎo)。
    的頭像 發(fā)表于 04-23 09:26 ?339次閱讀

    GaN E-HEMTs的PCB布局經(jīng)驗總結(jié)

    GaN E-HEMTs的PCB布局經(jīng)驗總結(jié)
    的頭像 發(fā)表于 03-13 15:52 ?479次閱讀
    GaN E-HEMTs的PCB布局<b class='flag-5'>經(jīng)驗總結(jié)</b>

    FPGA設(shè)計調(diào)試流程

    調(diào)試,即Debug,有一定開發(fā)經(jīng)驗的人一定會明確這是設(shè)計中最復(fù)雜最磨人的部分。對于一個龐大復(fù)雜的FPGA工程而言,出現(xiàn)問題的概率極大,這時如果沒有一個清晰的Debug思路,調(diào)試過程只能是像無頭蒼蠅一樣四處亂撞。
    的頭像 發(fā)表于 03-04 11:02 ?1131次閱讀
    FPGA設(shè)計<b class='flag-5'>調(diào)試</b>流程

    Linux系統(tǒng)安全加固經(jīng)驗總結(jié)

    修改 /etc/ssh/sshd_config 中 允許root 用戶登錄 PermitRootLogin 的值改為 false。
    的頭像 發(fā)表于 03-03 10:07 ?304次閱讀
    Linux系統(tǒng)安全加固<b class='flag-5'>經(jīng)驗總結(jié)</b>

    PCB板子設(shè)計經(jīng)驗(基本入門指導(dǎo)+經(jīng)驗總結(jié))【可下載】

    獲取資料可下載附件哦!!!!
    發(fā)表于 02-27 16:33

    DCDC 芯片無輸出的問題的調(diào)試經(jīng)驗

    該文檔聚焦于 DCDC 芯片無輸出的問題,分享調(diào)試經(jīng)驗,幫助工程師解決實際電路調(diào)試中的難題,主要內(nèi)容包括:*附件:【調(diào)試經(jīng)驗分享】DCDC芯
    的頭像 發(fā)表于 01-24 16:02 ?1129次閱讀

    電子工程師的電源設(shè)計經(jīng)驗分享

    作為一名電子工程師,電源設(shè)計一直是我在工作中重點關(guān)注的領(lǐng)域。電源設(shè)計不僅需要扎實的理論基礎(chǔ),還需要豐富的實踐經(jīng)驗。以下是我多年工作中總結(jié)的一些經(jīng)驗: 一、電源設(shè)計的核心理念 電源設(shè)計的核心是高效
    的頭像 發(fā)表于 01-21 15:53 ?409次閱讀

    光伏系統(tǒng)施工問題的注意事項

    隨著太陽能發(fā)電技術(shù)的日益成熟,光伏系統(tǒng)的應(yīng)用和安裝變得越來越普遍。建設(shè)一座安全高效的光伏電站,離不開高質(zhì)量的施工。通過近幾年的現(xiàn)場維護和經(jīng)驗總結(jié),本期小課堂將為大家分享一些光伏施工中的常見問題。
    的頭像 發(fā)表于 12-26 14:05 ?1124次閱讀

    KiCon 演講回顧(十五):提交 Kicad Bug

    “?Wayne Stambaugh 分享了如何提升 KiCad 用戶和開發(fā)者體驗的關(guān)鍵一環(huán):報告KiCad Bug。?” 完整的演講視頻在這里: KiCad的使命 KiCad旨在為專業(yè)電子設(shè)計師提供
    的頭像 發(fā)表于 12-11 09:09 ?450次閱讀
    KiCon 演講回顧(十五):提交 Kicad  <b class='flag-5'>Bug</b>

    電源環(huán)路快速調(diào)試理論與經(jīng)驗

    電源環(huán)路快速調(diào)試理論與經(jīng)驗 在工程實際應(yīng)用中,下圖所示有源補償網(wǎng)絡(luò)最常見: 有源補償網(wǎng)絡(luò)(一)的簡圖如下所示: 以上均屬于有源超前-滯后補償網(wǎng)絡(luò),其傳遞函數(shù)、零點和極點的推導(dǎo)公式詳見徐德鴻教授所著
    的頭像 發(fā)表于 11-28 10:59 ?680次閱讀
    電源環(huán)路快速<b class='flag-5'>調(diào)試</b>理論與<b class='flag-5'>經(jīng)驗</b>

    煙花爆竹企業(yè)電瓶車使用安全管理的當(dāng)前狀況與管理對策

    本文以四川省某煙花爆竹企業(yè)因電瓶車使用不當(dāng)引發(fā)的燃爆事故為實例,通過具體案例分析、經(jīng)驗總結(jié)及文獻參考等多種方法,綜合探討了煙花爆竹企業(yè)在使用電瓶車過程中面臨的問題,并提出了相應(yīng)的安全管理對策與措施。
    的頭像 發(fā)表于 10-28 10:37 ?741次閱讀
    煙花爆竹企業(yè)電瓶車使用安全管理的當(dāng)前狀況與管理對策

    Linux日志管理經(jīng)驗總結(jié)

    日志內(nèi)容,合理的日志內(nèi)容(日志錨點,內(nèi)容格式,等)可以為應(yīng)用服務(wù)的執(zhí)行記錄、問題排查提供最有力的幫助。
    的頭像 發(fā)表于 10-24 17:36 ?485次閱讀

    業(yè)務(wù)復(fù)雜度治理方法論--十年系統(tǒng)設(shè)計經(jīng)驗總結(jié)

    復(fù)雜度量公式 ? ? ? ? ? 子模塊的復(fù)雜度cp乘以該模塊對應(yīng)的開發(fā)時間權(quán)重值tp,累加后得到系統(tǒng)的整體復(fù)雜度C 這里的子模塊復(fù)雜度 cp是一個經(jīng)驗值 需要注意:如果一個子系統(tǒng)特別復(fù)雜,但是很少使用及修改,也不會對整體復(fù)雜度造成太大影響。例:spring框架內(nèi)部代
    的頭像 發(fā)表于 09-05 14:11 ?1255次閱讀
    業(yè)務(wù)復(fù)雜度治理方法論--十年系統(tǒng)設(shè)計<b class='flag-5'>經(jīng)驗總結(jié)</b>

    個人機智云開發(fā)實踐:經(jīng)驗總結(jié)與技術(shù)分享

    在個人的機智云開發(fā)過程中,主要包括以下幾個步驟1.項目創(chuàng)建與數(shù)據(jù)點設(shè)置2.在機智云平臺上創(chuàng)建項目并定義所需的數(shù)據(jù)點,這些數(shù)據(jù)點將用于設(shè)備和云端的通信。3.無線通信模塊固件燒錄4.下載并燒錄適用于所選無線模塊的GAgent固件。例如,我使用了正點原子的esp8266模塊,選擇了對應(yīng)的GAgentforESP8266固件。5.MCU方案代碼移植6.將機智云提供的
    的頭像 發(fā)表于 07-05 08:10 ?630次閱讀
    個人機智云開發(fā)實踐:<b class='flag-5'>經(jīng)驗總結(jié)</b>與技術(shù)分享

    瑞薩雙通道同步升壓控制器ISL81805調(diào)試經(jīng)驗分享及總結(jié)

    本文介紹了簡要介紹了瑞薩 ISL81805 的特性性能等,并通過電源調(diào)試,為大家分享了相關(guān)的經(jīng)驗和注意點。
    的頭像 發(fā)表于 06-17 18:54 ?2290次閱讀
    瑞薩雙通道同步升壓控制器ISL81805<b class='flag-5'>調(diào)試</b><b class='flag-5'>經(jīng)驗</b>分享及<b class='flag-5'>總結(jié)</b>
    主站蜘蛛池模板: 狠狠色噜噜狠狠狠狠999米奇 | 婷婷九月丁香 | 97影院理论 | 国产你懂的在线观看 | 丁香五月网久久综合 | 4438x成人免费 | 男人的天堂免费网站 | 在线观看国产一级强片 | 中文字幕在线色 | 久久综合九色综合97_ 久久久 | 6080yy午夜不卡一二三区 | 午夜黄网站 | 国产精品久久久久久久久免费观看 | 国产精品夜色7777青苹果 | 午夜视频在线观看一区 | 色爱区综合激情五月综合激情 | 黄色1级视频| 黄色免费看网站 | 五月激情丁香网 | 清冷双性被cao的合不拢腿 | 在线观看精品国产入口 | 日本在线不卡一区 | 四虎电影免费观看网站 | 中文字幕在线看精品乱码 | 男人你懂的在线观看视频 | 国产国产成人人免费影院 | 白嫩美女在线啪视频观看 | 免费观看三级毛片 | 日本色图网站 | 日本高清免费一本视频在线观看 | 亚洲欧美在线播放 | 色综合久久一区二区三区 | 亚洲网站免费观看 | 手机看片1024日韩 | 国产人成午夜免费看 | 一区二区不卡在线观看 | 永井玛丽亚中文在线观看视频 | 麻豆国产一区二区在线观看 | 国产日日夜夜 | 天天夜天干天天爽 | 狠狠躁夜夜躁人人爽天天3 狠狠躁夜夜躁人人爽天天段 |