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

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

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

減少調(diào)試時(shí)間的 3 個(gè)技巧

李微波 ? 來源:夜貓煮茶 ? 作者:夜貓煮茶 ? 2022-07-14 08:17 ? 次閱讀

There are a lot of potential changes that software development teams can make to decrease the time they spend debugging and get it into single-digit percentages.

工程師喜歡解決問題。這就是我們所做的。不幸的是,嵌入式軟件工程師最大的問題之一是我們制造了很多問題,然后通過花費(fèi)大量時(shí)間來修復(fù)它們(調(diào)試?。┦棺约撼蔀橛⑿?。嵌入式軟件工程師花費(fèi) 20% 到 40% 的時(shí)間進(jìn)行調(diào)試的公司很常見!值得慶幸的是,團(tuán)隊(duì)可以做出很多潛在的改變來減少他們花費(fèi)在調(diào)試上的時(shí)間,并將其降低到個(gè)位數(shù)的百分比。在本文中,我們將研究幾個(gè)減少調(diào)試時(shí)間的技巧。

提示 #1 – 擁抱測(cè)試驅(qū)動(dòng)開發(fā) (TDD)

測(cè)試驅(qū)動(dòng)開發(fā)是一種允許開發(fā)人員增量構(gòu)建他們的生產(chǎn)軟件的技術(shù),他們依靠測(cè)試來指示他們編寫的代碼。例如,TDD 讓開發(fā)人員首先編寫一個(gè)測(cè)試用例,使其失敗,然后只編寫允許該測(cè)試用例通過的代碼。然后重復(fù)該過程。

傳統(tǒng)上,嵌入式軟件開發(fā)人員會(huì)在測(cè)試之前編寫整個(gè)代碼模塊。在幾周內(nèi)編寫數(shù)千行代碼是可能的。那么,到了測(cè)試它的時(shí)候,如果它不起作用,問題在哪里呢?只有天知道!開發(fā)人員必須煞費(fèi)苦心地回顧代碼并發(fā)現(xiàn)問題所在并修復(fù)它。執(zhí)行此操作所需的時(shí)間可能相當(dāng)可觀。

另一方面,對(duì)于使用 TDD 的開發(fā)者來說,如果出現(xiàn)錯(cuò)誤并在代碼中注入了 bug,測(cè)試用例會(huì)立即告訴開發(fā)者!由于他們正在逐步編寫代碼,因此他們更有可能確切地知道他們所做的更改并可以立即解決問題。TDD 似乎需要更多時(shí)間來練習(xí),但它創(chuàng)建了一組可以在回歸測(cè)試中運(yùn)行的測(cè)試用例,以確保一切都按預(yù)期工作。TDD 一石二鳥:減少調(diào)試時(shí)間和自動(dòng)化測(cè)試。

提示 #2 – 盡可能多地開發(fā)脫靶

當(dāng)一個(gè)項(xiàng)目開始時(shí),幾乎每個(gè)嵌入式軟件開發(fā)人員的第一反應(yīng)就是獲得一塊開發(fā)板并開始編寫嵌入式代碼。不幸的是,在許多情況下,嵌入式代碼并不是我們產(chǎn)品的差異化因素。這是應(yīng)用程序代碼。雖然許多應(yīng)用程序代碼最終需要與硬件交互,但許多模塊可以脫靶開發(fā),即在主機(jī)上。

開發(fā)脫靶代碼為開發(fā)人員提供了許多減少每個(gè)調(diào)試周期所花費(fèi)時(shí)間的機(jī)會(huì)。例如,通常,要為目標(biāo)微控制器編寫和測(cè)試代碼,開發(fā)人員必須:

交叉編譯代碼

啟動(dòng)調(diào)試會(huì)話

通過 SWD 對(duì)設(shè)備進(jìn)行編程

在目標(biāo)上運(yùn)行代碼

通過在目標(biāo)上運(yùn)行代碼來驗(yàn)證代碼是否正常工作(還必須具有所有低級(jí)代碼)。

如果代碼是在主機(jī)上開發(fā)的,開發(fā)人員必須為主機(jī)編譯它,然后使用單元測(cè)試工具、仿真器或自定義程序來運(yùn)行正在開發(fā)的代碼。如果發(fā)現(xiàn)問題,修復(fù)、重新編譯并重新開始會(huì)更快。在嵌入式目標(biāo)上,僅對(duì)目標(biāo)進(jìn)行編程就會(huì)使每個(gè)周期增加幾十秒,更不用說單步執(zhí)行代碼的誘惑了。

脫靶開發(fā)/調(diào)試可能會(huì)產(chǎn)生特定的錯(cuò)誤。但是,我現(xiàn)在編寫了大約 75% 的代碼偏離目標(biāo),并且發(fā)現(xiàn)我的速度更快、效率更高。我可以快速?gòu)?qiáng)制代碼中的問題,確定原因,修復(fù)它,然后繼續(xù)前進(jìn),而不是通過嵌入式目標(biāo)跟蹤問題。當(dāng)然,有些事情會(huì)出現(xiàn)在目標(biāo)上,而不會(huì)出現(xiàn)在主機(jī)上。

提示 #3 – 掌握調(diào)試策略

人類已知的效率最低的調(diào)試方法是單步調(diào)試代碼行。不要誤會(huì)我的意思,有時(shí)間和地點(diǎn),但往往會(huì)浪費(fèi)很多時(shí)間。不幸的是,嵌入式軟件開發(fā)人員默認(rèn)使用斷點(diǎn)和單步調(diào)試。為了更好地調(diào)試,開發(fā)人員需要掌握現(xiàn)代微控制器上可用的其他調(diào)試策略。

今天,至少有八種不同的調(diào)試技術(shù)可供開發(fā)人員使用。這些技術(shù)從最簡(jiǎn)單到最復(fù)雜的順序包括:

Watch / Expressions:為開發(fā)人員提供檢查 CPU 和外設(shè)寄存器的能力。它們通常可用于監(jiān)視變量、執(zhí)行計(jì)算或在更改時(shí)停止 CPU。

斷點(diǎn):為開發(fā)人員提供在特定代碼行上停止 CPU 執(zhí)行的能力。高級(jí)斷點(diǎn)可用于設(shè)置條件語句。

printf:為開發(fā)人員提供將字符數(shù)據(jù)打印到映射的串行接口的能力。根據(jù)實(shí)現(xiàn),這可能會(huì)或可能不會(huì)影響實(shí)時(shí)性能。

斷言:這些是用于驗(yàn)證程序中特定點(diǎn)的假設(shè)的條件語句。斷言失敗通常會(huì)停止 CPU 并提供失敗斷言的文件和行位置。

Statistical Profiling:對(duì)應(yīng)用程序中的各種寄存器進(jìn)行定期采樣,這些寄存器同時(shí)發(fā)生在其運(yùn)行中。通常不會(huì)影響實(shí)時(shí)性能。例如,可能想要對(duì)程序計(jì)數(shù)器 (PC) 進(jìn)行采樣以了解正在執(zhí)行的代碼模塊。

數(shù)據(jù)分析:對(duì)包含可變數(shù)據(jù)的各種內(nèi)存位置進(jìn)行定期采樣。當(dāng)與實(shí)時(shí)可視化工具一起使用來監(jiān)控系統(tǒng)狀態(tài)、感興趣的變量變化等時(shí),數(shù)據(jù)分析會(huì)非常有用。

任務(wù)和數(shù)據(jù)跟蹤:使開發(fā)人員能夠跟蹤實(shí)時(shí)操作系統(tǒng)應(yīng)用程序中的事件。因此,開發(fā)人員可以深入了解應(yīng)用程序性能、任務(wù)延遲、運(yùn)行時(shí)間等等。

指令跟蹤:使開發(fā)人員能夠記錄在處理器上執(zhí)行的每條指令。這可用于了解測(cè)試期間的代碼覆蓋率、調(diào)試編譯器問題等。

掌握所有這些技術(shù)并知道何時(shí)使用它們可以大大減少當(dāng)缺陷確實(shí)進(jìn)入系統(tǒng)時(shí)用于調(diào)試的時(shí)間。

結(jié)論

可能會(huì)花費(fèi)大量時(shí)間調(diào)試嵌入式軟件。有時(shí),調(diào)試時(shí)間是無法避免的;但是,在許多情況下,開發(fā)人員可能會(huì)花費(fèi)比他們需要的時(shí)間更多的時(shí)間。我們已經(jīng)探索了幾個(gè)您可以進(jìn)一步調(diào)查的領(lǐng)域,以減少您和您的團(tuán)隊(duì)花費(fèi)在調(diào)試上的時(shí)間。如果您花費(fèi)超過 20% 的時(shí)間進(jìn)行調(diào)試,請(qǐng)?jiān)诒局芑ㄒ粋€(gè)小時(shí)確定您可以立即開始進(jìn)行哪些更改,以控制您花在調(diào)試上的時(shí)間。

審核編輯 黃昊宇

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

    關(guān)注

    5046

    文章

    18821

    瀏覽量

    298631
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    551

    瀏覽量

    33764
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    通過優(yōu)化補(bǔ)償最大限度地減少導(dǎo)通時(shí)間抖動(dòng)和紋波

    電子發(fā)燒友網(wǎng)站提供《通過優(yōu)化補(bǔ)償最大限度地減少導(dǎo)通時(shí)間抖動(dòng)和紋波.pdf》資料免費(fèi)下載
    發(fā)表于 08-26 11:34 ?0次下載
    通過優(yōu)化補(bǔ)償最大限度地<b class='flag-5'>減少</b>導(dǎo)通<b class='flag-5'>時(shí)間</b>抖動(dòng)和紋波

    開發(fā)攻略之STM32調(diào)試端口的映射

    最近有一個(gè)項(xiàng)目用到了STM32F103RB系列單片機(jī),由于引腳數(shù)量較少,不得不使用到了單片機(jī)的PB3和PB4兩個(gè)引腳。而這兩個(gè)引腳剛好又是STM32系列的JTAG
    的頭像 發(fā)表于 08-03 08:11 ?219次閱讀
    開發(fā)攻略之STM32<b class='flag-5'>調(diào)試</b>端口的映射

    時(shí)間繼電器應(yīng)用的三個(gè)關(guān)鍵點(diǎn)是什么?

    時(shí)間繼電器應(yīng)用的三個(gè)關(guān)鍵點(diǎn):選型、安裝和調(diào)試。 一、時(shí)間繼電器的選型 確定時(shí)間繼電器的類型 時(shí)間
    的頭像 發(fā)表于 06-21 10:00 ?359次閱讀

    具備“制造意識(shí)“的超構(gòu)透鏡設(shè)計(jì)或可減少設(shè)計(jì)階段到生產(chǎn)階段轉(zhuǎn)換時(shí)間

    ? 融入“制造意識(shí)”(Manufacturing Awareness)的設(shè)計(jì)是一種設(shè)計(jì)哲學(xué),它強(qiáng)調(diào)在產(chǎn)品設(shè)計(jì)和開發(fā)過程中對(duì)制造過程的理解和考慮。這種設(shè)計(jì)方法的目的是減少設(shè)計(jì)階段到生產(chǎn)階段的轉(zhuǎn)換時(shí)間
    的頭像 發(fā)表于 06-18 16:51 ?933次閱讀
    具備“制造意識(shí)“的超構(gòu)透鏡設(shè)計(jì)或可<b class='flag-5'>減少</b>設(shè)計(jì)階段到生產(chǎn)階段轉(zhuǎn)換<b class='flag-5'>時(shí)間</b>

    談?wù)凟MC,工程師必須知道的58個(gè)EMC問答

    1要對(duì)產(chǎn)品做電磁兼容設(shè)計(jì)?答:滿足產(chǎn)品功能要求、減少調(diào)試時(shí)間,使產(chǎn)品滿足電磁兼容標(biāo)準(zhǔn)的要求,使產(chǎn)品不會(huì)對(duì)系統(tǒng)中的其它設(shè)備產(chǎn)生電磁干擾。2對(duì)產(chǎn)品做電磁兼容設(shè)計(jì)可以從哪幾個(gè)方面進(jìn)行?答:電路設(shè)計(jì)(包括
    的頭像 發(fā)表于 06-13 08:28 ?341次閱讀
    談?wù)凟MC,工程師必須知道的58<b class='flag-5'>個(gè)</b>EMC問答

    如何有效減少PCBA的打樣時(shí)間

    一站式PCBA智造廠家今天為大家講講PCBA加工如何減少打樣時(shí)間?有效減少PCBA打樣時(shí)間的方法。 如今,國(guó)內(nèi)電子加工業(yè)十分繁榮,作為專業(yè)PCBA加工廠家,訂單完成得越快越好,尤其是針
    的頭像 發(fā)表于 06-04 09:27 ?208次閱讀

    使用4芯M9插頭可減少安裝時(shí)間

    德索工程師說道在探討使用4芯M9插頭是否能減少安裝時(shí)間之前,我們需要先明確安裝時(shí)間的影響因素。安裝時(shí)間的長(zhǎng)短通常取決于多個(gè)因素,如連接器的設(shè)計(jì)復(fù)雜度、安裝操作的難易程度、以及安裝工具的
    的頭像 發(fā)表于 04-17 14:44 ?725次閱讀
    使用4芯M9插頭可<b class='flag-5'>減少</b>安裝<b class='flag-5'>時(shí)間</b>嗎

    PLC控制系統(tǒng)實(shí)際調(diào)試中常見的三大問題

    用PC設(shè)計(jì)一個(gè)控制系統(tǒng)時(shí),一個(gè)最重要的參數(shù)就是時(shí)間,PC執(zhí)行程序中的所有指令要用多少時(shí)間,(掃描時(shí)間)有一
    發(fā)表于 03-08 14:06 ?463次閱讀

    miniprog3不能調(diào)試的原因?

    這邊有三個(gè)MINIPROG3不能調(diào)試,可以下載程序,但是調(diào)試的話,界面卡,芯片型號(hào)出不來,不能調(diào)試
    發(fā)表于 02-18 06:20

    Arm調(diào)試架構(gòu)基礎(chǔ)知識(shí)詳解

    調(diào)試是軟件開發(fā)的一個(gè)重要組成部分,通常是最消耗時(shí)間的(也因此非常昂貴)。錯(cuò)誤可以是很難察覺、重現(xiàn)和修復(fù)的,而且也難以預(yù)料解決一個(gè)缺陷需要多長(zhǎng)的時(shí)間
    的頭像 發(fā)表于 01-02 10:45 ?2087次閱讀
    Arm<b class='flag-5'>調(diào)試</b>架構(gòu)基礎(chǔ)知識(shí)詳解

    shell腳本調(diào)試技巧

    /a.txt.ori/tmp/a.txtset+x 提示: 開啟調(diào)試功能通過set -x 命令,而關(guān)閉調(diào)試功能通過set +x 5、習(xí)慣 最關(guān)鍵的是熟練語法,編碼習(xí)慣,編程思想,將錯(cuò)誤扼殺在萌芽狀態(tài),減少調(diào)試負(fù)擔(dān),提高效率。
    發(fā)表于 12-28 16:57

    伺服電機(jī)調(diào)試和選型方法

    伺服電機(jī)的選型和調(diào)試是實(shí)現(xiàn)精準(zhǔn)控制和提高工業(yè)自動(dòng)化效率的關(guān)鍵步驟。正確的選型和調(diào)試可以顯著提升機(jī)械系統(tǒng)的性能,減少維護(hù)成本,延長(zhǎng)設(shè)備使用壽命。以下是伺服電機(jī)調(diào)試和選型的詳盡步驟。
    的頭像 發(fā)表于 12-25 14:34 ?762次閱讀

    ADI-視頻應(yīng)用調(diào)試入門指南

    ?在如此重壓之下,很難有邏輯又有條理地調(diào)試個(gè)問題。而邏輯條理地調(diào)試問題卻恰恰是及時(shí)找到解決方案的關(guān)鍵所在。 顯然,完整的調(diào)試框架可以大量節(jié)省工程師的
    發(fā)表于 11-28 14:19 ?0次下載
    ADI-視頻應(yīng)用<b class='flag-5'>調(diào)試</b>入門指南

    如何在 CFD 設(shè)計(jì)中利用網(wǎng)格維護(hù)幾何形狀并減少運(yùn)行時(shí)間?

    如何在 CFD 設(shè)計(jì)中利用網(wǎng)格維護(hù)幾何形狀并減少運(yùn)行時(shí)間?
    的頭像 發(fā)表于 11-24 17:07 ?403次閱讀
    如何在 CFD 設(shè)計(jì)中利用網(wǎng)格維護(hù)幾何形狀并<b class='flag-5'>減少運(yùn)行時(shí)間</b>?

    Python中關(guān)于時(shí)間輸出和轉(zhuǎn)化的3個(gè)模塊

    1. 時(shí)間戳 1.1時(shí)間戳簡(jiǎn)介 在正式講解時(shí)間的相關(guān)函數(shù)之前,我們必須先一個(gè)概念: 時(shí)間戳 。本文中特指 unix
    的頭像 發(fā)表于 11-01 11:29 ?454次閱讀
    Python中關(guān)于<b class='flag-5'>時(shí)間</b>輸出和轉(zhuǎn)化的<b class='flag-5'>3</b><b class='flag-5'>個(gè)</b>模塊