女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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)試地獄的五個(gè)簡(jiǎn)單技巧

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

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

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

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

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

poYBAGN3S-GAJgWeAAGZXegH8Es210.png

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

調(diào)試時(shí)更好的洞察力意味著猜測(cè)更少,找到根本原因的幾率更高。在無法使用傳統(tǒng)方法(如在斷點(diǎn)上停止系統(tǒng))的情況下,它也有很大幫助。

你說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 通常非常慢,每次打印輸出大約幾毫秒。相比之下,軟件事件跟蹤的優(yōu)化解決方案可以比這快 100 倍左右,允許您在同一時(shí)間段內(nèi)收集更多信息。

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

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

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

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

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

使用跟蹤工具將跟蹤數(shù)據(jù)連續(xù)流式傳輸?shù)街鳈C(jī),如有必要,您可以在主計(jì)算機(jī)上存儲(chǔ)很長(zhǎng)的記錄,甚至可以在屏幕上實(shí)時(shí)顯示數(shù)據(jù)。跟蹤流使您能夠監(jiān)視系統(tǒng)測(cè)試或查找難以重現(xiàn)的罕見錯(cuò)誤。可視化跟蹤診斷允許在高級(jí)可視化概述中發(fā)現(xiàn)異常,并向下鉆取到特定事件以準(zhǔn)確了解發(fā)生了什么。

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

此方法允許記錄應(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í)別獲得所需的實(shí)時(shí)行為可見性,以提高產(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ī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19811

    瀏覽量

    233600
  • RTOS
    +關(guān)注

    關(guān)注

    24

    文章

    841

    瀏覽量

    120779
收藏 人收藏

    評(píng)論

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

    工控一體機(jī)多線程任務(wù)調(diào)度優(yōu)化:聚徽分享破解工業(yè)復(fù)雜流程高效協(xié)同密碼

    在當(dāng)今工業(yè) 4.0 的浪潮下,工業(yè)生產(chǎn)正朝著高度自動(dòng)化、智能化的方向大步邁進(jìn)。生產(chǎn)流程日益復(fù)雜,眾多任務(wù)需要同時(shí)、高效地協(xié)同執(zhí)行,這對(duì)工業(yè)控制系統(tǒng)的核心 —— 工控一體機(jī)提出了前所未有的挑戰(zhàn)。多線程
    的頭像 發(fā)表于 05-28 14:06 ?98次閱讀

    使用Percepio View免費(fèi)跟蹤工具分析Zephyr應(yīng)用

    Percepio View免費(fèi)跟蹤工具現(xiàn)在可以針對(duì)Zephyr應(yīng)用程序進(jìn)行跟蹤和可視化分析了。Percepio View可以幫助開發(fā)人員理解和調(diào)試Zephyr中的固定優(yōu)先級(jí)的多線程行為及復(fù)雜的線程交互。
    的頭像 發(fā)表于 05-27 15:08 ?119次閱讀
    使用Percepio View免費(fèi)跟蹤工具分析Zephyr應(yīng)用

    一種實(shí)時(shí)多線程VSLAM框架vS-Graphs介紹

    針對(duì)現(xiàn)有VSLAM系統(tǒng)語(yǔ)義表達(dá)不足、地圖可解釋性差的問題,本文提出vS-Graphs,一種實(shí)時(shí)多線程VSLAM框架。該方案顯著提升了重建地圖的語(yǔ)義豐富度、可解釋性及定位精度。實(shí)驗(yàn)表明
    的頭像 發(fā)表于 04-19 14:07 ?281次閱讀
    一種實(shí)時(shí)<b class='flag-5'>多線程</b>VSLAM框架vS-Graphs介紹

    請(qǐng)問如何在Python中實(shí)現(xiàn)多線程與多進(jìn)程的協(xié)作?

    大家好!我最近在開發(fā)一個(gè)Python項(xiàng)目時(shí),需要同時(shí)處理多個(gè)任務(wù),且每個(gè)任務(wù)需要不同的計(jì)算資源。我想通過多線程和多進(jìn)程的組合來實(shí)現(xiàn)并發(fā),但遇到了一些問題。 具體來說,我有兩個(gè)任務(wù),一個(gè)
    發(fā)表于 03-11 06:57

    請(qǐng)問rt-thread studio如何進(jìn)行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時(shí)cpu的占用率也只能到30%,編譯完整個(gè)工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎
    發(fā)表于 02-19 08:30

    Tracealyzer如何簡(jiǎn)化調(diào)試

    如果沒有專為多線程代碼設(shè)計(jì)的有效調(diào)試和分析工具,開發(fā)基于Zephyr的軟件可能更具有挑戰(zhàn)性。Percepio Tracealyzer可讓您快速解決問題并加快日常開發(fā)。優(yōu)化您的系統(tǒng)以獲得可靠的實(shí)時(shí)性能,獲取免費(fèi)評(píng)估非常方便,你在15分鐘內(nèi)開始使用這個(gè)軟件。
    的頭像 發(fā)表于 02-11 11:11 ?383次閱讀
    Tracealyzer如何簡(jiǎn)化<b class='flag-5'>調(diào)試</b>

    Wine開發(fā)系列——如何使用Wine日志調(diào)試問題

    ? 輸出調(diào)試日志是調(diào)試程序的一種常見方法,尤其是處理那些難以捉摸的多線程錯(cuò)誤、隨機(jī)崩潰等問題時(shí)。 通過在合適的位置輸出調(diào)試日志,可以幫助我們更快地定位問題所在。 對(duì)于不熟悉的代碼,經(jīng)常
    的頭像 發(fā)表于 01-06 11:29 ?835次閱讀

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

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

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

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

    一文掌握Python多線程

    使用線程可以把占據(jù)長(zhǎng)時(shí)間的程序中的任務(wù)放到后臺(tái)去處理。
    的頭像 發(fā)表于 08-05 15:46 ?1195次閱讀

    LWIP多線程強(qiáng)烈建議開啟LWIP_ASSERT_CORE_LOCKED宏,這個(gè)在RTT里面要怎么實(shí)現(xiàn)?

    LWIP多線程強(qiáng)烈建議開啟LWIP_ASSERT_CORE_LOCKED宏,這個(gè)在RTT里面要怎么實(shí)現(xiàn),之前參考網(wǎng)上代碼,這樣寫,壓力測(cè)試下有概率斷言失敗 extern sys_mutex_t
    發(fā)表于 07-25 06:27

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

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

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

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

    探索虛擬線程:原理與實(shí)現(xiàn)

    的開銷。首先,創(chuàng)建成本不菲,因?yàn)槊慨?dāng)操作系統(tǒng)需要?jiǎng)?chuàng)建一個(gè)新的平臺(tái)線程時(shí),它必須分配大量的內(nèi)存(通常以兆字節(jié)計(jì))來存儲(chǔ)線程的上下文信息、本機(jī)棧和Java調(diào)用棧。這一過程受到固定大小堆棧的限制,導(dǎo)致創(chuàng)建和調(diào)度平臺(tái)
    的頭像 發(fā)表于 06-24 11:35 ?529次閱讀
    探索虛擬<b class='flag-5'>線程</b>:原理與實(shí)現(xiàn)

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

    ://www.javadoop.com/post/java-thread-pool? 引言 在后臺(tái)項(xiàng)目開發(fā)過程中,我們常常借助線程池來實(shí)現(xiàn)多線程任務(wù),以此提升系統(tǒng)的吞吐率和響應(yīng)性;而線程池的參數(shù)配置
    的頭像 發(fā)表于 06-13 15:43 ?1481次閱讀
    動(dòng)態(tài)<b class='flag-5'>線程</b>池思想學(xué)習(xí)及實(shí)踐