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

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

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

多線程RTOS應(yīng)用程序的五個(gè)最佳實(shí)踐

星星科技指導(dǎo)員 ? 來(lái)源:嵌入式計(jì)算設(shè)計(jì) ? 作者:Dr. Johan Kraft ? 2022-06-21 09:45 ? 次閱讀

多線程 RTOS 應(yīng)用程序的一個(gè)更被低估的方面是您不能只查看代碼來(lái)完全了解應(yīng)用程序的工作原理。

你需要知道它的各個(gè)部分是如何相互通信的,并且你需要很多其他信息:任務(wù)執(zhí)行需要多長(zhǎng)時(shí)間,是否有任何潛在的競(jìng)爭(zhēng)條件或死鎖,你是否滿足你的時(shí)間要求等等。

您希望代碼做什么和它實(shí)際做什么可能在許多方面有所不同,這些方面既難以在代碼中看到,也難以測(cè)試。這對(duì)所有使用多線程代碼的開發(fā)人員來(lái)說(shuō)都是一個(gè)挑戰(zhàn),無(wú)論他們使用的是 RTOS 還是 Linux,最好使用可視化跟蹤診斷工具進(jìn)行管理,讓您深入了解我所說(shuō)的代碼的“黑暗面”——您可以從字面上理解看看它在執(zhí)行時(shí)的行為。

視覺(jué)時(shí)間線是一個(gè)很好的起點(diǎn)。在許多情況下,查看隨時(shí)間分布的軟件事件、消息和任務(wù)執(zhí)行很重要,例如當(dāng)錯(cuò)誤的精確位置從癥狀中不明顯時(shí)——計(jì)算機(jī)可能在數(shù)字處理和文本日志中搜索方面表現(xiàn)出色,但通常你不知道要搜索什么。在視覺(jué)模式識(shí)別方面,人腦表現(xiàn)出色。

poYBAGKxIueAGXUIAAHh_MLBOpY601.png

顯示軟件事件的可視化時(shí)間線可以讓您大致了解嵌入式應(yīng)用程序的內(nèi)部工作原理,如果您需要深入挖掘以查找錯(cuò)誤,這是一個(gè)很好的起點(diǎn)。

調(diào)試時(shí)更好的洞察力意味著將有更少的猜測(cè),并且更有可能找到根本原因。在無(wú)法使用傳統(tǒng)方法(如在斷點(diǎn)處暫停系統(tǒng))的情況下,它也是一個(gè)很大的幫助。

你說(shuō) printf 調(diào)試怎么樣?是的,printf 很容易部署,有時(shí)它確實(shí)是你所需要的,但它的價(jià)格很高。將調(diào)試打印輸出放在對(duì)時(shí)間敏感的應(yīng)用程序代碼中是有風(fēng)險(xiǎn)的,并且不能很好地?cái)U(kuò)展到更復(fù)雜的應(yīng)用程序和更快的處理器。此外, printf 通常非常慢,每次打印輸出大約為幾毫秒。相比之下,針對(duì)軟件事件跟蹤的優(yōu)化解決方案可以比這快大約 100 倍,允許您在同一時(shí)期收集更多信息。

確保在整個(gè)開發(fā)項(xiàng)目中測(cè)量時(shí)間和性能。做得對(duì),這可以確保您可以在開發(fā)過(guò)程中發(fā)現(xiàn)并解決任何問(wèn)題,而不是在承諾的交付日期之前與時(shí)間賽跑。

滿足時(shí)序規(guī)范對(duì)于具有嚴(yán)格要求的實(shí)時(shí)系統(tǒng)至關(guān)重要,但對(duì)于幾乎所有嵌入式系統(tǒng)的用戶體驗(yàn)也很重要。沒(méi)有人喜歡遲緩的觸摸屏或無(wú)法提供承諾吞吐量的慢速 wifi 路由器。同樣,根本原因從源代碼中可能并不明顯,如果真正的問(wèn)題是糟糕的軟件設(shè)計(jì),那么簡(jiǎn)單地切換到更快的處理器可能沒(méi)有任何好處。

如果你發(fā)現(xiàn)自己在一個(gè)項(xiàng)目中“調(diào)試地獄”,大量的調(diào)試會(huì)消耗房間里的所有能量并阻止項(xiàng)目向前推進(jìn),那么視覺(jué)跟蹤診斷可以幫助你。在基于 RTOS 的應(yīng)用程序的軟件設(shè)計(jì)中未能遵循最佳實(shí)踐通常是一個(gè)主要的促成因素,并且它可能以例如性能差、處理器負(fù)載高或瞬態(tài)錯(cuò)誤的形式出現(xiàn)。任務(wù)之間的大量依賴是另一個(gè)可以改進(jìn)設(shè)計(jì)的常見(jiàn)信號(hào)。

即使是架構(gòu)糟糕的系統(tǒng)也可能在今天運(yùn)行,但它們將具有復(fù)雜和混亂的行為以及較差的可測(cè)試性,這增加了泄漏到生產(chǎn)設(shè)備中的難以捉摸的錯(cuò)誤的風(fēng)險(xiǎn)。而且它們幾乎肯定會(huì)很脆弱,因此代碼或環(huán)境中的微小變化都會(huì)導(dǎo)致它們失敗。

可視化跟蹤診斷幫助開發(fā)人員分析和改進(jìn)他們的軟件設(shè)計(jì),確保系統(tǒng)行為穩(wěn)定可靠。當(dāng)您可以更早地發(fā)現(xiàn)軟件設(shè)計(jì)缺陷時(shí),修復(fù)它們所需的更改就會(huì)更少。設(shè)計(jì)改進(jìn)還可以帶來(lái)更好的系統(tǒng)性能和響應(yīng)能力,這反過(guò)來(lái)又可以讓您選擇更具成本效益的處理器來(lái)降低 BoM 成本或使用更低的時(shí)鐘頻率來(lái)延長(zhǎng)電池壽命。

使用您的跟蹤工具將跟蹤數(shù)據(jù)連續(xù)流式傳輸?shù)街鳈C(jī),如果需要,您可以在其中存儲(chǔ)很長(zhǎng)的記錄,甚至在屏幕上實(shí)時(shí)顯示數(shù)據(jù)。跟蹤流使您能夠監(jiān)控系統(tǒng)測(cè)試或?qū)ふ译y以重現(xiàn)的罕見(jiàn)錯(cuò)誤。視覺(jué)跟蹤診斷允許在高級(jí)視覺(jué)概覽中發(fā)現(xiàn)異常并深入到特定事件以準(zhǔn)確找出發(fā)生了什么。

最后,可視化跟蹤診斷可以實(shí)現(xiàn)為純軟件解決方案,不需要額外的硬件,甚至不需要調(diào)試探針。在內(nèi)存和處理器使用方面存在成本,但通常不會(huì)超過(guò)您可以在整個(gè)開發(fā)、測(cè)試甚至部署過(guò)程中將其保留在系統(tǒng)中(如果您愿意)。在所有階段都能獲得這些信息意味著每個(gè)人每天都能從中受益。

這種方法允許記錄來(lái)自應(yīng)用程序的任何相關(guān)信息,包括在運(yùn)行時(shí)未公開的內(nèi)部數(shù)據(jù)和狀態(tài)。數(shù)據(jù)可以與可視化執(zhí)行時(shí)間線并行繪制,以便在運(yùn)行時(shí)深入了解您的應(yīng)用程序。這樣,您就可以制作出能夠擊敗競(jìng)爭(zhēng)對(duì)手的出色產(chǎn)品。

遵循這五個(gè)最佳實(shí)踐,在系統(tǒng)級(jí)別獲得對(duì)實(shí)時(shí)行為所需的可見(jiàn)性,以提高產(chǎn)品質(zhì)量并加快開發(fā)速度,從而更快地進(jìn)入市場(chǎng)。

審核編輯:郭婷

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)注

    68

    文章

    19384

    瀏覽量

    230511
  • RTOS
    +關(guān)注

    關(guān)注

    22

    文章

    817

    瀏覽量

    119769
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4809

    瀏覽量

    68825
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    socket 多線程編程實(shí)現(xiàn)方法

    是指在同一個(gè)進(jìn)程中運(yùn)行多個(gè)線程,每個(gè)線程可以獨(dú)立執(zhí)行任務(wù)。線程共享進(jìn)程的資源,如內(nèi)存空間和文件句柄,但每個(gè)線程有自己的
    的頭像 發(fā)表于 11-12 14:16 ?421次閱讀

    Python中多線程和多進(jìn)程的區(qū)別

    Python作為一種高級(jí)編程語(yǔ)言,提供了多種并發(fā)編程的方式,其中多線程與多進(jìn)程是最常見(jiàn)的兩種方式之一。在本文中,我們將探討Python中多線程與多進(jìn)程的概念、區(qū)別以及如何使用線程池與進(jìn)程池來(lái)提高并發(fā)執(zhí)行效率。
    的頭像 發(fā)表于 10-23 11:48 ?446次閱讀
    Python中<b class='flag-5'>多線程</b>和多進(jìn)程的區(qū)別

    RTOS的特性和類型

    實(shí)時(shí)操作系統(tǒng)(RTOS)是一種可運(yùn)行實(shí)時(shí)計(jì)算應(yīng)用程序的軟件平臺(tái),用于處理具有明確時(shí)間約束的事件和數(shù)據(jù)。與通用操作系統(tǒng)(GPOS)不同,RTOS必須在有限的硬件資源上調(diào)度應(yīng)用程序之間的處
    的頭像 發(fā)表于 08-20 11:29 ?639次閱讀

    RTOS開發(fā)最佳實(shí)踐

    基于RTOS編寫應(yīng)用程序時(shí),有一些要注意事項(xiàng)。在本節(jié)中,您將學(xué)習(xí)RTOS開發(fā)最佳實(shí)踐,例如POSIX合規(guī)性、安全性和功能安全認(rèn)證。
    的頭像 發(fā)表于 08-20 11:24 ?486次閱讀

    ESP32會(huì)不會(huì)有多線程問(wèn)題,需要加鎖嗎?

    ESP32會(huì)不會(huì)有多線程問(wèn)題,需要加鎖嗎
    發(fā)表于 07-19 08:05

    多線程設(shè)計(jì)模式到對(duì) CompletableFuture 的應(yīng)用

    最近在開發(fā) 延保服務(wù) 頻道頁(yè)時(shí),為了提高查詢效率,使用到了多線程技術(shù)。為了對(duì)多線程方案設(shè)計(jì)有更加充分的了解,在業(yè)余時(shí)間讀完了《圖解 Java 多線程設(shè)計(jì)模式》這本書,覺(jué)得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?385次閱讀
    從<b class='flag-5'>多線程</b>設(shè)計(jì)模式到對(duì) CompletableFuture 的應(yīng)用

    動(dòng)態(tài)線程池思想學(xué)習(xí)及實(shí)踐

    相關(guān)文檔 美團(tuán)線程實(shí)踐:https://tech.meituan.com/2020/04/02/java-pooling-pratice-in-meituan.html 線程池思想解析:https
    的頭像 發(fā)表于 06-13 15:43 ?1217次閱讀
    動(dòng)態(tài)<b class='flag-5'>線程</b>池思想學(xué)習(xí)及<b class='flag-5'>實(shí)踐</b>

    bootloader開多線程做引導(dǎo)程序,跳app初始化后直接進(jìn)hardfualt,為什么?

    如標(biāo)題,想做一個(gè)遠(yuǎn)程升級(jí)的項(xiàng)目,bootloader引導(dǎo)區(qū)域和app都是開多線程跑的,就是自己寫了個(gè)小的任務(wù)調(diào)度器,沒(méi)什么功能主要是想讓程序快速的響應(yīng),延時(shí)不會(huì)對(duì)其他
    發(fā)表于 04-18 06:07

    鴻蒙OS開發(fā)實(shí)例:【ArkTS類庫(kù)多線程CPU密集型任務(wù)TaskPool】

    CPU密集型任務(wù)是指需要占用系統(tǒng)資源處理大量計(jì)算能力的任務(wù),需要長(zhǎng)時(shí)間運(yùn)行,這段時(shí)間會(huì)阻塞線程其它事件的處理,不適宜放在主線程進(jìn)行。例如圖像處理、視頻編碼、數(shù)據(jù)分析等。 基于多線程并發(fā)機(jī)制處理CPU密集型任務(wù)可以提高CPU
    的頭像 發(fā)表于 04-01 22:25 ?869次閱讀
    鴻蒙OS開發(fā)實(shí)例:【ArkTS類庫(kù)<b class='flag-5'>多線程</b>CPU密集型任務(wù)TaskPool】

    鴻蒙APP開發(fā):【ArkTS類庫(kù)多線程】TaskPool和Worker的對(duì)比

    TaskPool(任務(wù)池)和Worker的作用是為應(yīng)用程序提供一個(gè)多線程的運(yùn)行環(huán)境,用于處理耗時(shí)的計(jì)算任務(wù)或其他密集型任務(wù)??梢杂行У乇苊膺@些任務(wù)阻塞主線程,從而最大化系統(tǒng)的利用率,降
    的頭像 發(fā)表于 03-26 22:09 ?683次閱讀
    鴻蒙APP開發(fā):【ArkTS類庫(kù)<b class='flag-5'>多線程</b>】TaskPool和Worker的對(duì)比

    【從0開始創(chuàng)建AWTK應(yīng)用程序】編譯應(yīng)用到RTOS平臺(tái)

    AWStudio上編寫好AWTK應(yīng)用程序后,部署到RTOS平臺(tái)(如STM32)是很方便的,下面就以STM32F429型號(hào)為例子來(lái)介紹如何編譯AWTK應(yīng)用到RTOS
    的頭像 發(fā)表于 03-21 08:23 ?648次閱讀
    【從0開始創(chuàng)建AWTK<b class='flag-5'>應(yīng)用程序</b>】編譯應(yīng)用到<b class='flag-5'>RTOS</b>平臺(tái)

    java實(shí)現(xiàn)多線程的幾種方式

    Java實(shí)現(xiàn)多線程的幾種方式 多線程是指程序中包含了兩個(gè)或以上的線程,每個(gè)線程都可以并行執(zhí)行不同
    的頭像 發(fā)表于 03-14 16:55 ?765次閱讀

    基于RTOS的應(yīng)用進(jìn)程中的典型線程

    RTOS中的關(guān)鍵因素是最小的中斷延遲和最小的線程切換延遲。RTOS的價(jià)值在于它的響應(yīng)速度或可預(yù)測(cè)性,而不是它在給定時(shí)間段內(nèi)可以執(zhí)行的工作量。
    發(fā)表于 03-05 09:32 ?662次閱讀
    基于<b class='flag-5'>RTOS</b>的應(yīng)用進(jìn)程中的典型<b class='flag-5'>線程</b>

    AT socket可以多線程調(diào)用嗎?

    請(qǐng)問(wèn)AT socket 可以多線程調(diào)用嗎? 有互鎖機(jī)制嗎,還是要自己做互鎖。
    發(fā)表于 03-01 08:22

    幾點(diǎn)RTOS相比裸機(jī)的優(yōu)勢(shì)分享

    相比前后臺(tái)系統(tǒng)中后臺(tái)順序執(zhí)行的程序主體,在多線程系統(tǒng)中,根據(jù)程序的功能,我們把這個(gè)程序主體分割成一個(gè)個(gè)獨(dú)立的,無(wú)限循環(huán)且不能返回的小
    發(fā)表于 01-24 18:21 ?847次閱讀
    幾點(diǎn)<b class='flag-5'>RTOS</b>相比裸機(jī)的優(yōu)勢(shì)分享