99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

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

李微波 ? 來源:夜貓煮茶 ? 作者:夜貓煮茶 ? 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ù)它們(調(diào)試?。┦棺约撼蔀橛⑿?。嵌入式軟件工程師花費 20% 到 40% 的時間進行調(diào)試的公司很常見!值得慶幸的是,團隊可以做出很多潛在的改變來減少他們花費在調(diào)試上的時間,并將其降低到個位數(shù)的百分比。在本文中,我們將研究幾個減少調(diào)試時間的技巧。

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

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

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

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

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

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

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

交叉編譯代碼

啟動調(diào)試會話

通過 SWD 對設(shè)備進行編程

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

結(jié)論

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

審核編輯 黃昊宇

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

    關(guān)注

    5152

    文章

    19678

    瀏覽量

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

    關(guān)注

    7

    文章

    612

    瀏覽量

    34750
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

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

    硬件調(diào)試:JLink 驅(qū)動配置與調(diào)試技巧

    摘要: 本文深入探討了 JLink 調(diào)試器在嵌入式系統(tǒng)硬件調(diào)試中的應(yīng)用,詳細(xì)闡述了 JLink 驅(qū)動配置的方法以及硬件調(diào)試技巧。本文以國科安芯的AS32系列MCU芯片為例,通過分析 JLink
    的頭像 發(fā)表于 06-12 23:20 ?518次閱讀
    硬件<b class='flag-5'>調(diào)試</b>:JLink 驅(qū)動配置與<b class='flag-5'>調(diào)試</b>技巧

    伺服電機過載燒毀這3參數(shù)調(diào)試細(xì)節(jié)

    深入剖析伺服電機過載保護的三大關(guān)鍵參數(shù)——過載保護系數(shù)、電子齒輪比和加速度曲線,結(jié)合工程實踐中的調(diào)試技巧,幫助讀者構(gòu)建系統(tǒng)化的參數(shù)優(yōu)化方案。 一、過載保護系數(shù)的動態(tài)平衡藝術(shù) 過載保護系數(shù)(OLP)是伺服驅(qū)動器的第一
    的頭像 發(fā)表于 05-20 07:44 ?430次閱讀

    FX3 GPIF CyU3PGpifWriteDataWords的傳輸時間延遲的原因?

    據(jù)包之間存在明顯的延遲(7~9us)。 我有幾個問題: 1.如何才能減少數(shù)據(jù)包之間的時間? 我希望它們能夠持續(xù)下去。 2.CyU3PGpifWriteDataWords 是否僅適用于寄存器使用? 有沒有我
    發(fā)表于 05-15 06:18

    如何減少dsp啟動時間?

    如何減少dsp啟動時間?之前圖中Boot code(-bcode)設(shè)置為0x1時,DSP啟動時間大概為9秒。設(shè)置為0x2后,DSP的啟動時間大概為1秒。對于Boot code(-bco
    發(fā)表于 04-15 06:14

    請問MPC5748G如何減少啟動時間?

    我正在使用 MCP5748G。通電后大約需要 100 多毫秒才能正常工作。 正常啟動時間是多少毫秒?如何減少啟動時間?
    發(fā)表于 04-10 07:31

    58道問題!電子產(chǎn)品電磁兼容性學(xué)習(xí)問答~

    58問答搞懂電子產(chǎn)品電磁兼容性(EMC)核心問題,涵蓋設(shè)計、測試與整改要點。Chrent問答部分1.為什么要對產(chǎn)品做電磁兼容設(shè)計?答:滿足產(chǎn)品功能要求、減少調(diào)試時間,使產(chǎn)品滿足電磁兼容標(biāo)準(zhǔn)的要求
    的頭像 發(fā)表于 04-02 17:33 ?635次閱讀
    58道問題!電子產(chǎn)品電磁兼容性學(xué)習(xí)問答~

    在SPI通信中啟動SCLK之前如何減少CS低電平時間?

    ,如捕獲的圖像所示。 在 SCLK 開始之前,我可以采取哪些步驟來減少 CS 低電平時間?有什么指導(dǎo)或建議嗎?
    發(fā)表于 03-24 07:33

    如何調(diào)試時間繼電器 時間繼電器的工作時間設(shè)置方法

    1. 了解時間繼電器的基本原理 在開始調(diào)試之前,了解時間繼電器的工作原理是非常重要的。時間繼電器通常由一輸入電路、一
    的頭像 發(fā)表于 12-09 10:40 ?4573次閱讀

    socket編程中的錯誤處理技巧

    :錯誤處理能夠確保程序在遇到異常情況時不會崩潰,而是能夠優(yōu)雅地處理問題。 提升用戶體驗 :通過適當(dāng)?shù)腻e誤處理,可以給用戶提供清晰的錯誤信息,避免用戶感到困惑。 便于調(diào)試和維護 :良好的錯誤處理可以幫助開發(fā)者快速定位問題,減少調(diào)試時間
    的頭像 發(fā)表于 11-01 17:47 ?1557次閱讀

    【AI技術(shù)支持】ESP32-S3 JTAG調(diào)試問題處理

    啟明云端/01你是否曾遇到過?在使用ESP32-S3模塊,ESP-IDF版本為idf5.0時,調(diào)試JTAG,嘗試很久也無法調(diào)通,這是為什么呢?啟明云端/02這是咋回事呢?這個過程需要安裝zadig
    的頭像 發(fā)表于 10-30 08:01 ?2251次閱讀
    【AI技術(shù)支持】ESP32-S<b class='flag-5'>3</b> JTAG<b class='flag-5'>調(diào)試</b>問題處理

    【AI技術(shù)支持】ESP32C3 開發(fā)板在Linux環(huán)境下,進行JTAG 調(diào)試演示

    啟明云端/01JTAG調(diào)試工具本教程主要演示ESP32C3開發(fā)板在linux環(huán)境下,通過vscode的ESP-IDF插件使用JTAG調(diào)試工具。ESP32C3不但內(nèi)置了USB-JTAG,
    的頭像 發(fā)表于 10-17 08:01 ?3427次閱讀
    【AI技術(shù)支持】ESP32C<b class='flag-5'>3</b> 開發(fā)板在Linux環(huán)境下,進行JTAG <b class='flag-5'>調(diào)試</b>演示

    TDA3xx ISS調(diào)優(yōu)和調(diào)試基礎(chǔ)設(shè)施

    電子發(fā)燒友網(wǎng)站提供《TDA3xx ISS調(diào)優(yōu)和調(diào)試基礎(chǔ)設(shè)施.pdf》資料免費下載
    發(fā)表于 10-11 10:16 ?0次下載
    TDA<b class='flag-5'>3</b>xx ISS調(diào)優(yōu)和<b class='flag-5'>調(diào)試</b>基礎(chǔ)設(shè)施

    使用tSPI協(xié)議減少下一多電機BLDC設(shè)計的布線

    電子發(fā)燒友網(wǎng)站提供《使用tSPI協(xié)議減少下一多電機BLDC設(shè)計的布線.pdf》資料免費下載
    發(fā)表于 09-26 10:40 ?0次下載
    使用tSPI協(xié)議<b class='flag-5'>減少</b>下一<b class='flag-5'>個</b>多電機BLDC設(shè)計的布線

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

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

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

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