多線程 RTOS 應(yīng)用程序的一個更被低估的方面是,您不能只查看代碼來完全理解應(yīng)用程序的工作原理。
你需要知道它的各個部分是如何相互通信的,你需要很多其他信息:任務(wù)需要多長時間才能執(zhí)行,是否存在任何潛在的競爭條件或死鎖,你是否滿足你的計時要求等等。
您希望代碼執(zhí)行的操作和實際執(zhí)行的操作可能在許多方面有所不同,這些差異在代碼中既難以看到,也難以測試。對于所有使用多線程代碼的開發(fā)人員來說,無論他們使用 RTOS 還是 Linux,這都是一個挑戰(zhàn),最好使用可視化跟蹤診斷工具進行管理,這些工具可以讓您深入了解我所說的代碼的“黑暗面”——您可以從字面上看到它在執(zhí)行時的行為。
視覺時間線是一個很好的起點。在許多情況下,查看隨時間分布的軟件事件、消息和任務(wù)執(zhí)行非常重要,例如,當(dāng)從癥狀中看不出錯誤的確切位置時,計算機在數(shù)字處理和文本日志中搜索方面可能非常出色,但通常您不知道要搜索什么。在視覺模式識別方面,人腦表現(xiàn)出色。
顯示軟件事件的可視化時間線為您提供了嵌入式應(yīng)用程序內(nèi)部工作的概述,如果您需要深入挖掘以查找錯誤,這是一個很好的起點。
調(diào)試時更好的洞察力意味著猜測更少,找到根本原因的幾率更高。在無法使用傳統(tǒng)方法(如在斷點上停止系統(tǒng))的情況下,它也有很大幫助。
你說printf調(diào)試呢?是的,printf 易于部署,有時它確實是您所需要的,但它的價格很高。將調(diào)試打印輸出放在對時間敏感的應(yīng)用程序代碼中是有風(fēng)險的,并且不能很好地擴展到更復(fù)雜的應(yīng)用程序和更快的處理器。此外,printf 通常非常慢,每次打印輸出大約幾毫秒。相比之下,軟件事件跟蹤的優(yōu)化解決方案可以比這快 100 倍左右,允許您在同一時間段內(nèi)收集更多信息。
確保在整個開發(fā)項目中測量時間和性能。如果做得好,這可以確保您能夠在開發(fā)過程中檢測和解決任何問題,而不是在承諾的交付日期之前與時間賽跑。
滿足時序規(guī)格對于具有硬要求的實時系統(tǒng)至關(guān)重要,但對于幾乎任何嵌入式系統(tǒng)的用戶體驗也很重要。沒有人喜歡緩慢的觸摸屏或慢速的wifi路由器,因為它無法提供承諾的吞吐量。同樣,從源代碼來看,根本原因可能并不明顯,如果真正的問題是糟糕的軟件設(shè)計,簡單地切換到更快的處理器可能沒有任何好處。
如果您發(fā)現(xiàn)自己處于項目的“調(diào)試地獄”中,大量的調(diào)試會消耗房間中的所有能量并阻止項目向前發(fā)展,那么可視化跟蹤診斷可以幫助您。在基于 RTOS 的應(yīng)用程序的軟件設(shè)計中未能遵循最佳實踐通常是一個主要因素,它可能以性能差、處理器負載高或瞬態(tài)錯誤等形式出現(xiàn)。任務(wù)之間的大量依賴關(guān)系是設(shè)計可以改進的另一個常見信號。
即使是架構(gòu)不佳的系統(tǒng)今天也可能運行,但它們將具有復(fù)雜和混亂的行為,再加上糟糕的可測試性,這增加了難以捉摸的錯誤泄漏到生產(chǎn)設(shè)備的風(fēng)險。而且它們幾乎肯定會很脆弱,因此代碼或環(huán)境中的微小更改可能會導(dǎo)致它們失敗。
可視化跟蹤診斷可幫助開發(fā)人員分析和改進其軟件設(shè)計,并確保穩(wěn)定可靠的系統(tǒng)行為。當(dāng)您能夠更早地發(fā)現(xiàn)軟件設(shè)計缺陷時,修復(fù)它們所需的更改更少。設(shè)計改進還可以帶來更好的系統(tǒng)性能和響應(yīng)能力,這反過來又可以讓您選擇更具成本效益的處理器來降低 BoM 成本或使用較低的時鐘頻率以延長電池壽命。
使用跟蹤工具將跟蹤數(shù)據(jù)連續(xù)流式傳輸?shù)街鳈C,如有必要,您可以在主計算機上存儲很長的記錄,甚至可以在屏幕上實時顯示數(shù)據(jù)。跟蹤流使您能夠監(jiān)視系統(tǒng)測試或查找難以重現(xiàn)的罕見錯誤??梢暬櫾\斷允許在高級可視化概述中發(fā)現(xiàn)異常,并向下鉆取到特定事件以準(zhǔn)確了解發(fā)生了什么。
最后,可視化跟蹤診斷可以作為純軟件解決方案實現(xiàn),不需要額外的硬件,甚至不需要調(diào)試探針。內(nèi)存和處理器使用量是有成本的,但通常不超過這個成本,你可以在整個開發(fā)、測試甚至部署過程中將其保留在系統(tǒng)中。在所有階段都提供這些信息意味著每個人都每天都能從中受益。
此方法允許記錄應(yīng)用程序中的任何相關(guān)信息,包括運行時未公開的內(nèi)部數(shù)據(jù)和狀態(tài)。數(shù)據(jù)可以與可視化執(zhí)行時間線并行繪制,以便在運行時深入了解您的應(yīng)用程序。這樣,您可以制作出擊敗競爭對手的出色產(chǎn)品。
遵循這五個最佳實踐,在系統(tǒng)級別獲得所需的實時行為可見性,以提高產(chǎn)品質(zhì)量并加快開發(fā)速度,從而更快地進入市場。
審核編輯:郭婷
-
處理器
+關(guān)注
關(guān)注
68文章
19896瀏覽量
235313 -
RTOS
+關(guān)注
關(guān)注
24文章
851瀏覽量
121189
發(fā)布評論請先 登錄
多線程的安全注意事項
鴻蒙5開發(fā)寶藏案例分享---跨線程性能優(yōu)化指南
工控一體機多線程任務(wù)調(diào)度優(yōu)化:聚徽分享破解工業(yè)復(fù)雜流程高效協(xié)同密碼
使用Percepio View免費跟蹤工具分析Zephyr應(yīng)用

一種實時多線程VSLAM框架vS-Graphs介紹

HarmonyOS NEXT 原生應(yīng)用/元服務(wù)-ArkTS代碼調(diào)試worker/taskpool調(diào)試
請問如何在Python中實現(xiàn)多線程與多進程的協(xié)作?
請問rt-thread studio如何進行多線程編譯?
Tracealyzer如何簡化調(diào)試

Wine開發(fā)系列——如何使用Wine日志調(diào)試問題
socket 多線程編程實現(xiàn)方法
Python中多線程和多進程的區(qū)別

評論