單片機一種簡便的printf調試方案。

来源:https://www.cnblogs.com/bai2018/archive/2018/01/28/8367962.html
-Advertisement-
Play Games

此處引用csdn博客。鏈接如下、 http://blog.csdn.net/cp1300/article/details/7773239 http://blog.csdn.net/aobai219/article/details/6092292 我們在寫程式的時候,總是或多或少會加入一些printf ...


此處引用csdn博客。鏈接如下、

http://blog.csdn.net/cp1300/article/details/7773239

http://blog.csdn.net/aobai219/article/details/6092292

我們在寫程式的時候,總是或多或少會加入一些printf之類的語句用於輸出調試信息,但是printf語句有個很不方便的地方就是當我們需要發佈程式的時候要一條一條的把這些語句刪除,而一旦需要再次調試的時候,這些語句又不得不一條條的加上,這給我們帶來了很大的不便,浪費了我們很多的時間,也造成了調試的效率低下。所以,很多人會選擇使用巨集定義的方式來輸出調試語句。

作者通過兩文的閱讀,總結如下,並添加了自己的觀點。

引言

首先說明的是 printf("123!\n""!""243");

語法正確,即輸出等同printf("123!\n!243");

但是不似乎等同於printf("123!\n","!","243");

正文

1

假如有如下定義

#define EEPROM_ERROR(fmt,...)          printf("<<-EEPROM-ERROR->> "fmt"\n",##__VA_ARGS__)

… ’指可變參數。這類巨集在被調用時,它(這裡指‘ … ’)被表示成零個或多個符號,包括裡面的逗號,一直到到右括弧結束為止。當被調用時,在巨集體( macro body )中,那些符號序列集合將代替裡面的 保留名__VA_ARGS__ 標識符。如果可變參數被忽略或為空,‘ ## ’操作將使預處理器( preprocessor )去除掉它前面的那個逗號,這樣當巨集定義調用沒有變參時候,可以巨集替換時候沒有錯誤的逗號。

調用時候,使用如下語句

EEPROM_ERROR("a= %d,b=%d,c=%d",a,b,c);

這時替換結果為    "a= %d,b=%d,c=%d" 與 fmt       

a,b,c   與  ... (即__VA_ARGS__)

替換後相當於printf("<<-EEPROM-ERROR->> ""a= %d,b=%d,c=%d""\n",a,b,c);

2

假如有如下定義

#define EEPROM_INFO(fmt,arg...)           printf("<<-EEPROM-INFO->> "fmt"\n",##arg)

調用方法與1相同。不同的是,去掉了保留名__VA_ARGS__ 

3

為了使printf作為的調試信息更具體,將以上的調試方案更進一步

3.1

ANSI C標準中有幾個標準預定義巨集(也是常用的):

__LINE__:在源代碼中插入當前源代碼行號;

__FILE__:在源文件中插入當前源文件名;

3.2

在有些時候,\n並沒有輸出回車(環境為,win10+stc串口助手+stm32f429)。需要使用0x0d,0x0a之類的輸出回車。所以使用了\r\n作為一個回車效果

3.3

有如下定義:

#define EEPROM_ERROR(fmt,arg...)          printf("\r\n<<-EEPROM-ERROR->> \r\n""LIFE NAME:"__FILE__ "\r\n""LINE:%d\r\n"fmt"\r\n\n",__LINE__,##arg)

調用如下:

EEPROM_ERROR("answer is c= %d c=%d c= %d",d,d,d);//假設c變數為uint8_t類型,值為6,並假設使用在第49行調用

輸出結果為下:

<<-EEPROM-ERROR->>
LIFE NAME:..\User\main.c
LINE:49
answer is c= 6 c=6 c= 6

4

 

為了可以打開和關閉調試信息,可以將巨集定義修改為:

#define EEPROM_ERROR(fmt,arg...)          //printf("\r\n<<-EEPROM-ERROR->> \r\n""LIFE NAME:"__FILE__ "\r\n""LINE:%d\r\n"fmt"\r\n\n",__LINE__,##arg)

這樣子,在整個工程中的通過巨集定義方案輸出的調試信息全部消失。而不是去使用#ifdef之類的巨集定義開關語句開關巨集定義

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 假設以下場景,如果在客戶端運行程式,最的事情之一是有一個響應的用戶界面。這意味著無論應用程式發生什麼,所有的用戶界面元素都要保持 快速運行,用戶能夠從應用程式得到快速響應。達到這一點並不容易!如果你嘗試在Windows系統中打開記事本並載入一個有幾兆大小的文檔,應用程式視窗將交結一段的時間,因為整個... ...
  • 演示產品源碼下載地址:http://www.jinhusns.com ...
  • 在對接華為NB-IoT平臺時用到了https連接方式, 華為方面提供了crt格式的證書文件, 但官方只給了java範例, C#引用該證書時出現了問題, 下麵是踩的坑: NB_IoT平臺介面調試, https認證方式 NB_IoT平臺介面調試, https認證方式 首先在代碼中加入 1 Service ...
  • ...
  • 全國天氣預報 全國城市天氣預報,包含直轄市,省(港澳台),市,區,縣3級。 可查詢半月天氣預報。 支持定製多個城市。 下載地址:https://pan.baidu.com/s/1mjFeOPE ...
  • 前言 大家好,我是Rector 又是星期五,很興奮,很高興,很high...啦啦啦。。。 Rector在圖享網又和大家見面啦!!!上一篇《 "一步一步創建ASP.NET MVC5程式\[Repository+Autofac+Automapper+SqlSugar\" ][1]》,我們完成了: Aut ...
  • 概述:LINQ又稱為語言集成查詢,是一種類似於SQL的一種查詢語言。語言集成查詢讓開發人員可以使用.NET程式語言(如C#)去查詢數據源,主要數據源為記憶體中的集合對象、ADO.NET數據集、資料庫以及XML,開發人員不用去分門別類地學習眾多的查詢語法就可以輕鬆地查詢異構數據源。 三種表現形式:複合查 ...
  • 回到目錄 因為docker上的大部分鏡像都是基於linux系統的,所以在向圖像中寫中文時需要考慮中文字體問題,例如在microsoft/aspnetcore2.0這個鏡像,它是基於debian系統的,它上面只有一個英文字體,所以在輸出中文時會出現亂碼,這是正常的,我們的解決方案也需要按著以下步驟即可 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...