深入探討一下如何打斷點


對於程序員來說,debug的時間往往比寫程序的時間還要長。尤其對我這種專寫bug為主的程序員來說,正確使用斷點調試是提高效率的有效方法。今天我們聊聊如何高效率的斷點調試,由於工作中IAR為主力IDE,本篇文章主要以IAR為主。

01、普通斷點

打開IDE,如下圖,我們想在程序運行到第104行時停止運行,我們在下圖中104行號前單擊,這時該語句上將出現紅色的斷點標記。如下圖:

  或者點擊要設置斷點的語句,按鼠標右鍵,選擇Toggle Breakpoint (Code)。

02、條件斷點

除了上述最普通的斷點外,有時候我們需要斷點在一定條件下觸發,例如上面的代碼,希望在num等於100時程序暫停。這個時候有兩個最常用方法:

1、最笨的方法就是手動運行100次即可,如果是一次兩次的還可以,運行100次顯然不現實。

2、寫一個判斷語句,當num等於100時執行某個語句,把斷點打在這個語句上如下:

 這種方法可行,也很缺陷:當代碼開了優化時,某些語句可能被優化導致斷點無法運行。

這個時候,條件斷點就閃亮登場了。

在打好斷點之后,進入debug模式,然后在IAREWARM的選項欄選擇View-> Breakpoints 窗口查看所設置的斷點,右鍵已設置的斷點,選擇Edit進行配置斷點。

 我們希望當num等於100時暫停程序,那么我們下圖紅框內填寫num==100。當然也可以設置(num>= 10)和(num<= 10),類似C語言中使用的==、>=、<=。

 程序全速運行時,當程序運行到104行,且num等於100時就會暫停,如下圖

 注意我上面的用詞“且”,這時候斷點觸發的條件時運行到104行和num等於100同時滿足時,如果將斷點打到其他行也是一樣的效果,如下圖:

 03、數據斷點

看完上面的描述,有些同學就要問了,如果我就想要num等於100時暫停,不要同時滿足其他條件,為什么有這樣的需求呢?在實際的開發過程中,會碰到很多數據“異常”的情況,比如在一個代碼量很大的工程中,有個變量突然變成1,卻無法很快定位到那句代碼修改的。

這時候數據斷點(非官方叫法,個人叫法)就閃亮登場了。值得注意的是,數據斷點只對全局變量有效。

進入debug模式,然后在IAREWARM的選項欄選擇View-> Breakpoints 窗口查看所設置的斷點,空白處右鍵選擇NewBreakpoint,然后選擇Data。

 在1處填寫num,表示要監控的變量,選擇2處Enable,在3處寫入0x00000064,表示當num等於100時,暫停程序。

 測試結果如下

 眼尖的同學可能已經注意到,Accesstype選項,我們這個選擇的是Read/Write,表示無論是讀操作還是寫操作,當num等於100時,都會暫停程序。

當選擇Read時,只有讀num等於100時才會暫停程序,當選擇Write時,只有寫num時num等於100,才會暫停程序

對比如下圖,一個停在了106行,一個停在了104行,具體原因這個是C語言的基本知識,這里不再贅述。

  

注意:

1、對於Cortex-M 設備,只能設置一個帶有匹配數據的斷點。而且這樣的斷點使用兩個硬件斷點。

2、調試設備僅限於I-jet,JTAGjet,J-Link/J-Trace 和ST-LINK,如果使用的自制的CMSIS-DAP是不支持的。

04、總結

在新建斷點時,還有log,Datalog等等,這些我用得不多,上面主要介紹了我常用的打斷點的方式,希望對大家有幫助,原創分享不易,大家喜歡的話,點個在看,不想點在看,點個贊也可以。

 

點擊查看本文所在的專輯,STM32F207教程


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM