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

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

分享嵌入式軟件調試方法和幾個工具

strongerHuang ? 來源:嵌入式大雜燴 ? 作者:雜燴君 ? 2022-11-09 10:49 ? 次閱讀

我們常常說,軟件三分寫七分調。實際開發中,確實也是這樣子的。我工作這幾年了,對這體會也越來越深。每當需求一下來,我代碼很快就可以寫完,但是,調試需要花很多時間。

這里需要明確的是, 調試的目的不僅僅是調通整個功能需求 。調通功能是最基本的要求,還需要進行優化、完善邏輯、完善異常處理。所以,需要非常長的時間。

記得畢業的時候參與的第一個項目,那個項目的硬件架構相對一般產品來說會復雜一些:

71c51252-5fc5-11ed-8abf-dac502259ad0.png

我負責的部分就是D芯片的軟件。D芯片所做的事情就是跟產品功能比較相近的,當時通過A發數據,經過B、C之后,再到D,產品功能表現得不正常。我當時的 第一反應 就是我負責得D芯片的邏輯可能出問題了。

A、B、C都是比較有經驗的工程師負責的,而且負責C的還是個組長級別的,大家也覺得應該是我負責的D芯片的代碼出的問題,因為我是個剛畢業的新人,覺得問題出在我這里的概率比較大。

他們也沒有去查是不是他們的問題,每天就是來看看我是否有找到問題。花了幾天的時間,我最后才定位出來,是C芯片給我發的數據出問題了~

因為當時缺乏調試經驗,所以沒能很快就定位出問題所在。要是現在的話,這種問題很快就能查出來的。因為現在積累了一些經驗:

調試經驗

平時開發調試時,可能會有這么兩種情況:

  • 獨立開發,自己調試

  • 協作開發,聯合調試

1、獨立開發

一些小的項目,如果整個項目是我們自己開發的話,調試起來也比較方便,因為是我們自己開發的,所以會比較熟悉一些。

我的習慣是:分模塊來進行開發,每開發完一個模塊就先想辦法測一下這個模塊,沒問題了再集成到工程里。模塊初步開發、測試時,代碼可以隨意一些,調好了之后,再重新梳理、整理代碼,集成到工程里。

自測的方式:有一些代碼直接對應著功能,直接測試看功能正不正常;有一些代碼可以通過log打印來看是否正常;有一些可能需要在線調試看看是否符合預期;有一些需要數據輸入的,可以自己模擬一些數據等。

2、協同開發

協同開發時,可能就比較麻煩一些。特別的,有時候甚至需要跨部門對接調試。

我的習慣是:先開發并自測自己的模塊;然后模擬對方,簡單地自測通信

自測自己模塊的方式如上面獨立開發一樣。我們模擬對方進行測試時,需要考慮是不是需要花比較多的時間,如果需要花太多的時間的花就算了,等到聯調再一起調。

花時間較少的,可以自測通信的情況可能有如下三種:

  • 線程/進程間通信。這應該比較容易,模擬對方線程/進程進行收發測試。可以寫一些測試命令,比如發某個命令,觸發某條消息發送。
  • 板間通信,如串口通信。可以用串口助手模擬對方進行測試,自己對照協議模擬一些協議數據進行收發測試。
  • socket通信,如TCP通信。你負責客戶端,就模擬服務端;你負責服務端,就模擬客戶端。

當然,協作開發也可以不自測通信,看個人習慣。

我模擬自測通信是為了對我自己的模塊的通信有一定的把控,聯調時出問題時,就可以比較快地指出對方的問題。當然,這不是為了推鍋,而是為了能更好地分析、解決聯調問題。

比如,我最近的項目中,設備與手機APP對接。配網功能、設備于APP局域網內通信功能。我負責設備端,設備端作為服務器;對方作為客戶端。

在與對方聯調前,我已經寫了一個客戶端運行于PC或設備上,模擬對方的手機APP,對我的模塊做了基本的自測,也測出了我的模塊的一些問題。

然后在與對方正式聯調時,出現的大多問題都在對方那邊,所以這時候我就可以幫助對方分析問題,提高了聯調效率。

上面分享了一些我的經驗及思路,下面看看一些具體的調試方法與調試工具:

調試方法

1、LOG

我在實際工作中,log打印調試解決了我大多數的問題,一般的問題,通過分析log都可以定位出問題所在。但是,打log也是有很多講究的,需要我們打印出有助于我們調試的信息。

比如:

  • log的格式

帶時間戳、函數名、行號等有助于分析問題的信息。比如:

[func:100]

當然,實際中可能不只包含如上信息,根據需要添加。

  • 在一些判斷分支要加上log

這樣可以清楚地知道程序跑到分支判斷時的執行流程。

  • 在一些大的操作的開始處,加上顯眼的log

可以清楚地知道某個操作開始的地方。

  • 業務邏輯模塊,可以加上特定的標簽

比如統一的log的格式中加上特定標簽,比如BUSINESS。如:

[BUSINESS][func:100]

因為業務邏輯一般是整個項目地最上層,其它模塊都是為它服務的。

我們看log的時候,通過編輯器搜索關鍵字 BUSINESS 就可以只列出業務邏輯相關的log,我們只要看這些log,就可以大致知道程序的運行流程。

當然,其它模塊也可以根據需要加上標簽。

  • 控制log打印頻率

與數據打交道的模塊可能需要打印一些數據來分析源數據是否正常。可以稍微的控制打印頻率,盡可能在不影響數據分析的情況下打印盡可能少的log。

否則,一些log的文件動不動就幾百MB,分析起來也很頭疼。特別的,log需要保存在flash上時,為了防止log爆滿flash,常常需要限制log文件的大小并做log滾動覆蓋,這時候無效log太多了可能就會覆蓋掉有效的log。

往期關于log調試相關的文章:

C語言嵌入式中幾個非常實用的宏技巧

bug解決不了?使用日志法

分享一個極簡的log模塊!

嵌入式軟件打log的一些心得!

2、在線調試

在線調試,可以看到程序運行的更多細節。基本的應該都會吧。

GDB往期相關推文:

例說GDB調試

手把手教你使用VSCode + gdb + gdbserver調試ARM程序

GDB調試器的簡單使用(圖文)

關于keil的調試相關的內容,推薦看一下我同事魚鷹寫的文章(公眾號:魚鷹談單片機),他對這方面研究得比較深。

3、其它調試工具

我們公眾號之前也分享了很多有用的調試相關的工具:

(1)VirtLCD

這是一個實用的LCD模擬器,手頭上暫時沒有LCD或者開發初期,需要頻繁下載程序,驗證效果的時候,可以使用VirtLCD來提高我們的開發、調試效率。

VirtLCD的介紹及簡單使用:

實用 | 手頭上無LCD卻又急著開發UI?LCD模擬器了解一下~

(2)Wireshark

Wireshark 是一個網絡封包分析軟件。比如我們在調試socket通信的時候,可以使用Wireshark 監控看看我們有沒有發送數據出去,或者有沒有收到對方發送的數據。

wireshark的介紹及簡單使用:

wireshark抓包工具的使用及分析

(3)VSPD

Virtual Serial Port Driver(VSPD)是一個虛擬串口軟件。虛擬串口軟件是一種模擬物理串行接口的軟件,它完全復制了硬件 COM 接口的功能,并且將被操作系統和串行應用程序識別為真實端口

在編寫串口上位機時,需要進行調試。一種方式是與下位機進行通信進行測試;另一種方式是借助虛擬串口軟件來進行測試。

VSPD的介紹及簡單使用:

工具 | 虛擬串口軟件的使用分享

(4)LVGL GUI Guider

GUI Guider是恩智浦為LVGL開發了一個上位機GUI設計工具,可以通過拖放控件的方式設計LVGL GUI頁面,加速GUI的設計。

相關文章:

實用工具 | LVGL GUI-Guider的使用分享

基于vs2019的lvgl模擬器使用

lvgl最新版本在STM32上的移植使用

(5)Jlink+JScope

J-Scope 是 SEGGER 推出的波形顯示軟件,傻瓜式,簡單易上手。需要搭配 Jlink仿真器 (V9或V10)使用。

J-Scope的介紹及簡單使用:

J-Scope的介紹及簡單使用

(6)SEGGER_RTT

RTT全稱是Real Time Transmit(實時傳輸),是SEGGER 公司推出的,是搭配 Jlink仿真 (V9或V10)使用的一種調試手段。

SEGGER_RTT的介紹及簡單使用:

SEGGER_RTT的介紹及簡單使用

(7)CmBacktrace

CmBacktrace (Cortex Microcontroller Backtrace)是一款針對 ARM Cortex-M 系列 MCU 的錯誤代碼自動追蹤、定位,錯誤原因自動分析的開源庫。

CmBacktrace 的介紹及簡單使用:

CmBacktrace 的介紹及簡單使用

(8)VOFA+

VOFA+(伏特加)插件驅動的高自由度上位機。其是一款通用的數據調試工具,它讓圖形化調試變得像串口調試一樣簡單。通過打印字符串,或者發送十六進制數字的方式,就能完成數據的可視化操作。

官網:

https://www.vofa.plus/

VOFA+的介紹及簡單使用:

VOFA+的介紹及簡單使用

(9)QEMU

QEMU是一款知名的而且開源的模擬器(官網:https://www.qemu.org/),它能在 X86 PC 上運行能夠模擬 Arm、MIPS、RISC-V 等各種 CPU 和開發板,以及 網卡、聲卡、鍵盤、sdcard、emmc、usb等各種外設。

QEMU我還未使用過,之前轉載的一篇文章:

Linux利器:QEMU!用它模擬開發板能替代真開發板?

(10)Valgrind

Valgrind是一套Linux下,開放源代碼(GPL V2)的仿真調試工具的集合。

Valgrind的介紹及簡單使用:

工具 | Valgrind仿真調試工具的使用

(11)Bus hound

Bus hound是一款為了在pc電腦上進行總線數據包監控以及操控的開發工具。用來捕捉來自設備的協議包和輸入輸出操作,它是功能強大的總線協議分析器。

之前有與USB上位機聯調,通過這個工具可以監控上位機發出的數據是否正確。關于Bus hound的文章我們公眾號還沒有分享過,先占個坑,之后有機會再分享。

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 芯片
    +關注

    關注

    459

    文章

    52192

    瀏覽量

    436264
  • 模塊
    +關注

    關注

    7

    文章

    2783

    瀏覽量

    49596
  • 嵌入式
    +關注

    關注

    5141

    文章

    19537

    瀏覽量

    315038

原文標題:分享嵌入式軟件調試方法和幾個工具

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

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

    RTOS的編程和使用對于提升嵌入式軟件的實時性和穩定性至關重要。 開發環境:熟悉Keil、IAR、Eclipse等集成開發環境,以及JTAG、GDB等調試工具。 2)硬件接口與驅動開發 硬件接口
    發表于 04-15 14:37

    嵌入式軟件單元測試的必要性、核心方法工具深度解析

    一、為什么嵌入式軟件必須重視單元測試? ?嵌入式系統的特殊性? 在汽車 ECU、醫療設備控制器等場景中,軟件直接操控硬件,?單比特錯誤可能導致剎車失靈或呼吸機故障?。不同于 PC?
    的頭像 發表于 03-21 14:53 ?351次閱讀

    嵌入式軟件測試技術深度研究報告

    嵌入式軟件測試技術深度研究報告 ——基于winAMS的全生命周期質量保障體系構建 一、行業技術瓶頸與解決方案框架 2025年嵌入式軟件測試領域面臨兩大核心矛盾: ? 安全合規與開發效率
    的頭像 發表于 03-03 13:54 ?265次閱讀

    盤點工程師常用的嵌入式開發工具

    嵌入式開發涉及硬件與軟件的緊密結合,開發工具的選擇對效率和質量至關重要。以下是嵌入式開發中常用的工具分類及代表性
    的頭像 發表于 02-07 10:06 ?1683次閱讀

    如何提高嵌入式代碼質量?

    嵌入式代碼的質量是至關重要的。本文將探討如何通過有效的開發方法工具來提高嵌入式代碼的質量,以確保系統的可靠性和可維護性。 理解嵌入式
    發表于 01-15 10:48

    嵌入式工程師常用的開發工具有哪些?

    項目管理和調試。IAR Embedded Workbench 也是廣受歡迎的 IDE,具有出色的優化能力和調試工具,能夠幫助工程師快速開發出高質量的嵌入式軟件。 二、編譯器 編
    發表于 12-20 15:29

    嵌入式系統開發與硬件的關系 嵌入式系統開發常見問題解決

    系統開發與硬件關系的幾個關鍵點: 硬件依賴性 :嵌入式系統的軟件必須能夠在特定的硬件上運行,這包括處理器、內存、輸入/輸出接口等。軟件必須能夠充分利用硬件的特性,同時繞過其限制。 資源
    的頭像 發表于 12-09 09:38 ?844次閱讀

    嵌入式學習建議

    對廣大渴望學習嵌入式系統的學子提出幾點基礎階段的學習建議: ①嵌入式系統軟件硬件密切相關,一定要打好軟硬件基礎。其實,只要找到正確的方法,加上努力,任何理工科學生,甚至非理工科學生,
    發表于 10-22 11:41

    EsDA,一站嵌入式軟件

    EsDA是一套面向工業智能物聯領域的嵌入式系統設計自動化工具集,包含實時操作系統AWorksLP、低代碼開發平臺AWStudio、資源管理平臺AXPI、跨平臺GUI引擎AWTK和云服務平臺ZWS
    的頭像 發表于 09-15 08:10 ?650次閱讀
    EsDA,一站<b class='flag-5'>式</b><b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>

    嵌入式開發常用軟件有哪些?

    查看源代碼,注釋文檔等非常方便,因為它查找,定位,彩色顯示等功能非常強大。開發人員會當成源代碼閱讀工具使用。 4.Keil uVision5 Keil 5 軟件是一款功能強大的嵌入式系統開發
    發表于 09-09 15:22

    嵌入式軟件開發與AI整合

    嵌入式軟件開發與AI整合是當前技術發展的重要趨勢之一。隨著人工智能技術的快速發展,嵌入式系統越來越多地集成了AI算法,以實現更復雜的智能功能。以下是關于嵌入式
    的頭像 發表于 07-31 09:25 ?1237次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>開發與AI整合

    聚焦嵌入式開發中的合規性工具、項目管理工具、版本迭代工具應用

    ,就嵌入式開發與管理領域的最新趨勢、工具選擇以及DevSecOps實踐應用等方面展開了深入探討。 本期對話龍智資深DevSecOps顧問徐晨暉, 分享嵌入式開發中的合規性工具、項目管理
    的頭像 發表于 07-29 15:15 ?972次閱讀

    飛凌嵌入式Forlinx pinMux,更好用的MPU引腳復用配置工具

    飛凌嵌入式打造了一款專門針對ARM嵌入式MPU引腳復用的軟件工具——Forlinx pinMux
    的頭像 發表于 07-05 10:28 ?2480次閱讀
    飛凌<b class='flag-5'>嵌入式</b>Forlinx pinMux,更好用的MPU引腳復用配置<b class='flag-5'>工具</b>

    嵌入式系統怎么學?

    系統設計與調試:需要掌握嵌入式系統的設計方法調試技術,包括硬件設計、軟件設計、電路調試等,以確
    發表于 07-02 10:10

    如何提升嵌入式編程能力?

    、SPI、CAN、WIFI、MQTT等多種通信協議。 4. 使用開發工具:熟練掌握嵌入式開發工具,如編譯器、調試器、仿真器和實時操作系統(RTOS)。 5. 閱讀數據手冊:仔細閱讀你所使用的微控制器或
    發表于 06-21 10:01