一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

嵌入式軟件減少調(diào)試時(shí)間的技巧

Linux閱碼場(chǎng) ? 來(lái)源:Linux閱碼場(chǎng) ? 作者:許慶偉 ? 2022-06-30 10:01 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

工程師喜歡解決問(wèn)題。當(dāng)然,這就是我們的工作。但不如人愿的是,嵌入式軟件工程師最大的問(wèn)題之一是我們自己制造了很多問(wèn)題,然后花大量的時(shí)間來(lái)解決這些問(wèn)題,最后使自己成為英雄(在調(diào)試上!)。有很多公司的嵌入式軟件工程師把20 - 40%的時(shí)間花在調(diào)試上。值得慶幸的是,從團(tuán)隊(duì)的角度可以做出很多潛在的改變,以減少他們花在調(diào)試上的時(shí)間,并將時(shí)間百分比壓縮到個(gè)位數(shù)。在本文中,我們將研究一些減少調(diào)試時(shí)間的技巧。

技巧1-測(cè)試驅(qū)動(dòng)開(kāi)發(fā)(TDD)

測(cè)試驅(qū)動(dòng)開(kāi)發(fā)是一種允許開(kāi)發(fā)人員增量地構(gòu)建他們的產(chǎn)品軟件,并依賴測(cè)試來(lái)規(guī)定他們編寫(xiě)代碼的技術(shù)。例如,開(kāi)發(fā)人員首先編寫(xiě)一個(gè)測(cè)試用例,如果測(cè)試失敗,則編寫(xiě)以通過(guò)測(cè)試為目的新代碼。然后重復(fù)這個(gè)過(guò)程。

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

另一方面,對(duì)于使用TDD的開(kāi)發(fā)人員來(lái)說(shuō),如果出現(xiàn)了錯(cuò)誤并且在代碼中注入了bug,測(cè)試用例將立即告訴開(kāi)發(fā)人員!由于是逐步編寫(xiě)代碼的流程,所以更有可能確切地知道更改了程序的什么部分,并且能夠立即修復(fù)問(wèn)題。TDD似乎需要更多的時(shí)間來(lái)驗(yàn)證,但通過(guò)創(chuàng)建一系列的測(cè)試用例,可以在回歸測(cè)試中運(yùn)行這些用例,以確保一切都按照預(yù)期工作。TDD功能實(shí)現(xiàn)了一石二鳥(niǎo)的目的:減少調(diào)試和自動(dòng)化測(cè)試的時(shí)間。

技巧2-盡可能無(wú)機(jī)器依賴的開(kāi)發(fā)

當(dāng)一個(gè)項(xiàng)目開(kāi)始時(shí),幾乎每個(gè)嵌入式軟件開(kāi)發(fā)人員的第一反應(yīng)就是獲得一塊開(kāi)發(fā)板然后開(kāi)始編寫(xiě)代碼。 但不如人愿的是,在許多情況下嵌入式軟件代碼并不是和對(duì)手之間產(chǎn)品的差異化因素,差別在于應(yīng)用程序代碼。 雖然許多應(yīng)用程序代碼最終需要與硬件交互,但許多模塊可以不依賴于主機(jī)器環(huán)境來(lái)進(jìn)行開(kāi)發(fā)。

實(shí)施無(wú)機(jī)器依賴的代碼開(kāi)發(fā),為開(kāi)發(fā)人員提供了許多減少每個(gè)調(diào)試周期所花費(fèi)時(shí)間的機(jī)會(huì)。 例如,通常要為目標(biāo)微控制器編寫(xiě)和測(cè)試代碼,開(kāi)發(fā)人員必須做以下工作:

1.交叉編譯代碼

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

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

4.在目標(biāo)機(jī)器上運(yùn)行代碼

5.通過(guò)在目標(biāo)機(jī)上運(yùn)行來(lái)驗(yàn)證代碼是否有效(同樣的必須擁有所有Low-Level代碼)

如果代碼是在主機(jī)上開(kāi)發(fā)的,開(kāi)發(fā)人員必須在主機(jī)上編譯代碼,然后使用單元測(cè)試工具、仿真器或自定義程序來(lái)運(yùn)行正在開(kāi)發(fā)的代碼。 如果發(fā)現(xiàn)問(wèn)題,會(huì)更加快速的修復(fù)、重新編譯并重新開(kāi)始測(cè)試。

在嵌入式板子上,僅對(duì)目標(biāo)程序進(jìn)行編程就會(huì)使每個(gè)周期增加幾十秒,更不用說(shuō)單步執(zhí)行代碼了。

無(wú)機(jī)器依賴的開(kāi)發(fā)/調(diào)試可能會(huì)產(chǎn)生特定的錯(cuò)誤。從我現(xiàn)在寫(xiě)了大約 75% 的相關(guān)代碼的例子上來(lái)看,發(fā)現(xiàn)會(huì)有速度更快、效率更高的效果。 我可以快速定位代碼中的問(wèn)題,確定原因并修復(fù)它,然后繼續(xù)調(diào)試,而不是只能在嵌入式板子上跟蹤問(wèn)題。 當(dāng)然,有些問(wèn)題會(huì)出現(xiàn)在主機(jī)上不會(huì)出現(xiàn)的板子環(huán)境上。

技巧3-掌握調(diào)試策略

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

目前至少有八種不同的調(diào)試技術(shù)可供開(kāi)發(fā)人員使用。 這些技術(shù)從最簡(jiǎn)單到最復(fù)雜的順序排列如下:

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

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

打印:為開(kāi)發(fā)人員提供將字符數(shù)據(jù)打印到映射的串行接口的能力,有一定概率會(huì)影響實(shí)時(shí)性能。

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

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

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

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

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

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

結(jié)論

我們?cè)陂_(kāi)發(fā)階段可能會(huì)花費(fèi)大量時(shí)間調(diào)試嵌入式軟件代碼。 有時(shí)調(diào)試時(shí)間是不可避免的; 但在許多情況下,開(kāi)發(fā)人員可能會(huì)花費(fèi)超出預(yù)期更多的時(shí)間。 我們已經(jīng)探索了幾個(gè)您可以進(jìn)一步調(diào)查的領(lǐng)域,以減少您和您的團(tuán)隊(duì)花費(fèi)在調(diào)試上的時(shí)間。 如果您在調(diào)試上花費(fèi)超過(guò)整體軟件周期的20%時(shí)間,那么請(qǐng)?jiān)诒局芑ㄒ粋€(gè)小時(shí)時(shí)間確定您在以上哪些方面可以立即調(diào)整優(yōu)化,以控制花在調(diào)試上的時(shí)間。

審核編輯 :李倩

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

    關(guān)注

    7

    文章

    2788

    瀏覽量

    50427
  • 嵌入式軟件
    +關(guān)注

    關(guān)注

    4

    文章

    245

    瀏覽量

    27344
  • 驅(qū)動(dòng)開(kāi)發(fā)

    關(guān)注

    0

    文章

    134

    瀏覽量

    12316

原文標(biāo)題:減少嵌入式軟件調(diào)試時(shí)間的三個(gè)技巧

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場(chǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    嵌入式軟件開(kāi)發(fā)常用的軟件有哪些?

    、編譯和調(diào)試嵌入式系統(tǒng)軟件。它提供了一個(gè)集成的開(kāi)發(fā)環(huán)境(IDE),包括代碼編輯器、編譯器、調(diào)試器和仿真器等組件,這些組件可以方便地進(jìn)行配置和管理,提供了高效的開(kāi)發(fā)體驗(yàn)。Keil 5支持
    發(fā)表于 07-03 17:06

    泰克示波器 MSO58 混合信號(hào)示波器在嵌入式系統(tǒng)調(diào)試中的核心技巧

    嵌入式系統(tǒng)的開(kāi)發(fā)與調(diào)試中,泰克示波器 MSO58 混合信號(hào)示波器憑借其強(qiáng)大的功能和靈活的特性,成為工程師不可或缺的調(diào)試利器。掌握其核心調(diào)試技巧,能夠顯著提升
    的頭像 發(fā)表于 07-01 16:28 ?134次閱讀
    泰克示波器 MSO58 混合信號(hào)示波器在<b class='flag-5'>嵌入式</b>系統(tǒng)<b class='flag-5'>調(diào)試</b>中的核心技巧

    普源示波器MSO5074在嵌入式系統(tǒng)聯(lián)合調(diào)試中的高效實(shí)踐

    一、引言:嵌入式系統(tǒng)調(diào)試的挑戰(zhàn)與示波器的必要性 嵌入式系統(tǒng)作為核心控制單元廣泛應(yīng)用于汽車(chē)、醫(yī)療設(shè)備、工業(yè)自動(dòng)化等領(lǐng)域,其開(kāi)發(fā)涉及硬件設(shè)計(jì)、軟件編程及實(shí)時(shí)
    的頭像 發(fā)表于 06-20 13:45 ?174次閱讀
    普源示波器MSO5074在<b class='flag-5'>嵌入式</b>系統(tǒng)聯(lián)合<b class='flag-5'>調(diào)試</b>中的高效實(shí)踐

    嵌入式軟件行業(yè)增長(zhǎng)驅(qū)動(dòng)因素

    嵌入式軟件在物聯(lián)網(wǎng)應(yīng)用中至關(guān)重要,因?yàn)樗芾碓O(shè)備操作、控制傳感器、支持連接并確保數(shù)據(jù)安全。例如,在智能家居中,恒溫器、安全攝像頭和燈光等設(shè)備使用嵌入式系統(tǒng)獨(dú)立運(yùn)行,并通過(guò)云平臺(tái)或本地網(wǎng)絡(luò)與其他智能
    的頭像 發(fā)表于 05-09 11:26 ?347次閱讀

    嵌入式適合自學(xué)嗎?

    構(gòu)、時(shí)鐘系統(tǒng)、電源管理、存儲(chǔ)映射等。 嵌入式必學(xué)技術(shù)點(diǎn)↓↓↓ 1硬件與軟件的結(jié)合 2實(shí)時(shí)性要求與資源限制 3跨領(lǐng)域知識(shí)整合 4調(diào)試與測(cè)試?yán)щy 二)缺乏專業(yè)指導(dǎo) 1)容易走彎路:自學(xué)嵌入
    發(fā)表于 04-27 09:54

    如何成為一名嵌入式軟件工程師?

    RTOS的編程和使用對(duì)于提升嵌入式軟件的實(shí)時(shí)性和穩(wěn)定性至關(guān)重要。 開(kāi)發(fā)環(huán)境:熟悉Keil、IAR、Eclipse等集成開(kāi)發(fā)環(huán)境,以及JTAG、GDB等調(diào)試工具。 2)硬件接口與驅(qū)動(dòng)開(kāi)發(fā) 硬件接口
    發(fā)表于 04-15 14:37

    泰克MDO32示波器在嵌入式系統(tǒng)調(diào)試中的關(guān)鍵技術(shù)分析

    隨著現(xiàn)代電子技術(shù)的飛速發(fā)展,嵌入式系統(tǒng)在各個(gè)領(lǐng)域的應(yīng)用日益廣泛,從消費(fèi)電子到工業(yè)控制,再到汽車(chē)電子和航空航天等。嵌入式系統(tǒng)的復(fù)雜性不斷增加,使得調(diào)試工作變得尤為重要。泰克MDO32示波器作為一款
    的頭像 發(fā)表于 03-19 13:51 ?338次閱讀
    泰克MDO32示波器在<b class='flag-5'>嵌入式</b>系統(tǒng)<b class='flag-5'>調(diào)試</b>中的關(guān)鍵技術(shù)分析

    嵌入式機(jī)器學(xué)習(xí)的應(yīng)用特性與軟件開(kāi)發(fā)環(huán)境

    設(shè)備和智能傳感器)上,這些設(shè)備通常具有有限的計(jì)算能力、存儲(chǔ)空間和功耗。本文將您介紹嵌入式機(jī)器學(xué)習(xí)的應(yīng)用特性,以及常見(jiàn)的機(jī)器學(xué)習(xí)開(kāi)發(fā)軟件與開(kāi)發(fā)環(huán)境。 嵌入式機(jī)器學(xué)習(xí)的應(yīng)用特性與優(yōu)勢(shì) 由于嵌入式
    的頭像 發(fā)表于 01-25 17:05 ?668次閱讀
    <b class='flag-5'>嵌入式</b>機(jī)器學(xué)習(xí)的應(yīng)用特性與<b class='flag-5'>軟件</b>開(kāi)發(fā)環(huán)境

    如何提高嵌入式代碼質(zhì)量?

    嵌入式系統(tǒng)的發(fā)展已經(jīng)深刻地影響了我們?nèi)粘I畹姆椒矫婷妫瑥闹悄芗揖拥狡?chē)控制系統(tǒng),再到醫(yī)療設(shè)備和工業(yè)自動(dòng)化等領(lǐng)域,嵌入式系統(tǒng)無(wú)處不在。嵌入式軟件的質(zhì)量直接關(guān)系到系統(tǒng)的安全性、穩(wěn)定性和性
    發(fā)表于 01-15 10:48

    嵌入式系統(tǒng)開(kāi)發(fā)與硬件的關(guān)系 嵌入式系統(tǒng)開(kāi)發(fā)常見(jiàn)問(wèn)題解決

    嵌入式系統(tǒng)開(kāi)發(fā)與硬件的關(guān)系 嵌入式系統(tǒng)是專為特定應(yīng)用設(shè)計(jì)的計(jì)算機(jī)系統(tǒng),它們通常嵌入在所控制的設(shè)備中。這些系統(tǒng)的關(guān)鍵特點(diǎn)是它們與硬件的緊密集成,這意味著軟件必須為特定的硬件平臺(tái)量身定制。
    的頭像 發(fā)表于 12-09 09:38 ?976次閱讀

    什么是嵌入式?一文讀懂嵌入式主板

    在現(xiàn)代科技浪潮中,嵌入式技術(shù)已成為支撐各種智能設(shè)備和系統(tǒng)運(yùn)行的核心力量。那么,究竟什么是嵌入式?嵌入式系統(tǒng),顧名思義,是將計(jì)算機(jī)的硬件和軟件嵌入
    的頭像 發(fā)表于 10-16 10:14 ?2619次閱讀

    EsDA,一站嵌入式軟件

    ,旨在提高嵌入式軟件開(kāi)發(fā)的效率、性能和可擴(kuò)展性。EsDA全稱是嵌入式系統(tǒng)設(shè)計(jì)自動(dòng)化,它是一個(gè)由AWorksLP、AWStudio、AXPI、AWTK、ZWS等多種軟件
    的頭像 發(fā)表于 09-15 08:10 ?781次閱讀
    EsDA,一站<b class='flag-5'>式</b><b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>

    嵌入式開(kāi)發(fā)常用軟件有哪些?

    用于編寫(xiě)、編譯和調(diào)試嵌入式系統(tǒng)軟件。它提供了一個(gè)集成的開(kāi)發(fā)環(huán)境(IDE),包括代碼編輯器、編譯器、調(diào)試器和仿真器等組件,這些組件可以方便地進(jìn)行配置和管理,提供了高效的開(kāi)發(fā)體驗(yàn)。Keil
    發(fā)表于 09-09 15:22

    嵌入式系統(tǒng)中的實(shí)時(shí)操作系統(tǒng)

    嵌入式RTOS是嵌入式應(yīng)用程序運(yùn)行、相互交互和與外界通信的底層軟件機(jī)制。在本節(jié)中,您將了解嵌入式軟件開(kāi)發(fā)人員使用哪些流行RTOS以及它們運(yùn)行
    的頭像 發(fā)表于 08-20 11:28 ?892次閱讀

    嵌入式軟件開(kāi)發(fā)與AI整合

    嵌入式軟件開(kāi)發(fā)與AI整合是當(dāng)前技術(shù)發(fā)展的重要趨勢(shì)之一。隨著人工智能技術(shù)的快速發(fā)展,嵌入式系統(tǒng)越來(lái)越多地集成了AI算法,以實(shí)現(xiàn)更復(fù)雜的智能功能。以下是關(guān)于嵌入式
    的頭像 發(fā)表于 07-31 09:25 ?1376次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>開(kāi)發(fā)與AI整合