日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

好用的嵌入式設備日志輸出模塊 log.h

來源: 責編: 時間:2023-11-07 09:14:44 310觀看
導讀相信大多數嵌入式開發者都會碰到對程序進行調試或者查找BUG的情況,常見的兩種方法都是仿真和通過日志進行的。有條件仿真的是更好,單是在編寫嵌入式軟件程序過程中,并不是所有的硬件都支持仿真或者方便仿真,這樣大多數方

相信大多數嵌入式開發者都會碰到對程序進行調試或者查找BUG的情況,常見的兩種方法都是仿真和通過日志進行的。hIG28資訊網——每日最新資訊28at.com

有條件仿真的是更好,單是在編寫嵌入式軟件程序過程中,并不是所有的硬件都支持仿真或者方便仿真,這樣大多數方法便是加打印信息進行找問題。hIG28資訊網——每日最新資訊28at.com

打印的接口有很多種,比如串口,網絡,顯示等等。簡單的硬件開發串口估計是最常用的。這里簡單記錄下一種日志打印方法。hIG28資訊網——每日最新資訊28at.com

hIG28資訊網——每日最新資訊28at.com

目的:hIG28資訊網——每日最新資訊28at.com

  • 方便查找打印日志
  • 日志格式規范
  • 可以查看用戶添加信息,文件信息,函數接口,以及文件所在行號
  • 支持format格式
  • 可以支持實時時間

基本知識

C語言中的__FILE__、LINE__和__FUNCTION:hIG28資訊網——每日最新資訊28at.com

  • FILE 用于指示本行代碼所在源文件的文件名;
  • __LINE__用于指示本行代碼所在源文件中的位置(行數);
  • __FUNCTION__用于指示本行代碼所在函數(函數名);

注:hIG28資訊網——每日最新資訊28at.com

  • "FILE "、"LINE"、"FUNCTION"等均大小寫敏感
  • 支持需要添加頭文件#include

源碼

#define DEBUG_EN (1u) #if (DEBUG_EN) #define DEBUG_MAX_SIZE 512extern char szBuf[DEBUG_MAX_SIZE]; #define DEBUG_INFO( format, ... ) do{/    u16 unLen = 0;/    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE, "[INFO][%s][@%s][#%d]:",__FILE__,__FUNCTION__,__LINE__);/    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE-unLen, format, ## __VA_ARGS__ );/    usart1_send_buf_with_txe((u8 *)szBuf,unLen);/}while(0) #define DEBUG_WARN( format, ... ) do{/    u16 unLen = 0;/    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE, "[WARN][%s][@%s][#%d]:",__FILE__,__FUNCTION__,__LINE__);/    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE-unLen, format, ## __VA_ARGS__ );/    usart1_send_buf_with_txe((u8 *)szBuf,unLen);/}while(0) #define DEBUG_ERR( format, ... ) do{/    u16 unLen = 0;/    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE, "[ERR][%s][@%s][#%d]:",__FILE__,__FUNCTION__,__LINE__);/    unLen += snprintf(szBuf+unLen,DEBUG_MAX_SIZE-unLen, format, ## __VA_ARGS__ );/    usart1_send_buf_with_txe((u8 *)szBuf,unLen);/}while(0) #elif  #define DEBUG_INFO(...)#define DEBUG_WARN(...)#define DEBUG_ERR(...) #endif

hIG28資訊網——每日最新資訊28at.com

源碼主要使用宏定義的方式,為了支持文件、行號,函數等等,不能使用單獨的函數進行定義。具體原因可以思考下,不過多贅述。hIG28資訊網——每日最新資訊28at.com

C文件目前只有一個數組定義char szBuf[DEBUG_MAX_SIZE];。hIG28資訊網——每日最新資訊28at.com

為了兼容,INFO,WARN和ERR三個共用一個buf,聲明全局變量更主要的一個原因是使用了串口的中斷發送函數usart1_send_buf_with_txe,而不是循環發送完成再退出,這里傳輸是進行指針傳遞的,發送使用中斷的好處就是高效率,不耽誤其他程序跑。hIG28資訊網——每日最新資訊28at.com

當然移植的時候完全可以根據自己的接口和實現方式進行更換。hIG28資訊網——每日最新資訊28at.com

實現效果:

[INFO][../source/main.c][@main][#36]:testStr[111],testInt[111],testHex[0x000015BC][WARN][../source/main.c][@main][#37]:testStr[111],testInt[111],testHex[0x000015BC][ERR][../source/main.c][@main][#38]:testStr[111],testInt[111],testHex[0x000015BC]

圖片圖片hIG28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-17409-0.html好用的嵌入式設備日志輸出模塊 log.h

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 使用 Python 在視頻上渲染文本

下一篇: 虛擬線程原理及性能分析

標簽:
  • 熱門焦點
  • 俄羅斯:將審查iPhone等外國公司設備 保數據安全

    iPhone和特斯拉都屬于在各自領域領頭羊的品牌,推出的產品也也都是數一數二的,但對于一些國家而言,它們的產品可靠性和安全性還是在限制范圍內。近日,俄羅斯聯邦通信、信息技術
  • 6月安卓手機性價比榜:Note 12 Turbo斷層式碾壓

    6月份有一個618,雖然這是京東周年慶的日子,但別的電商也都不約而同的跟進了,反正促銷沒壞處,廠商和用戶都能滿意。618期間一些產品也出現了歷史低價,那么各個價位段的產品性價比
  • 5月安卓手機好評榜:魅族20 Pro奪冠

    性能榜和性價比榜之后,我們來看最后的安卓手機好評榜,數據來源安兔兔評測,收集時間2023年5月1日至5月31日,僅限國內市場。第一名:魅族20 Pro好評率:97.50%不得不感慨魅族老品牌還
  • Raft算法:保障分布式系統共識的穩健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可復制、可冗余、可容錯”)的首字母縮寫。Raft算法是一種用于在分布式系統
  • K6:面向開發人員的現代負載測試工具

    K6 是一個開源負載測試工具,可以輕松編寫、運行和分析性能測試。它建立在 Go 和 JavaScript 之上,它被設計為功能強大、可擴展且易于使用。k6 可用于測試各種應用程序,包括 Web
  • 讓我們一起聊聊文件的操作

    文件【1】文件是什么?文件是保存數據的地方,是數據源的一種,比如大家經常使用的word文檔、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存數據,它既可以保
  • 只需五步,使用start.spring.io快速入門Spring編程

    步驟1打開https://start.spring.io/,按照屏幕截圖中的內容創建項目,添加 Spring Web 依賴項,并單擊“生成”按鈕下載 .zip 文件,為下一步做準備。請在進入步驟2之前進行解壓。圖
  • 機構稱Q2全球智能手機出貨量同比下滑11% 蘋果份額依舊第2

    7月20日消息,據外媒報道,研究機構的報告顯示,由于需求下滑,今年二季度全球智能手機的出貨量,同比下滑了11%,三星、蘋果等主要廠商的銷量,較去年同期均有下
  • 蘋果MacBook Pro 2021測試:仍不支持平滑滾動

    據10月30日9to5 Mac 消息報道,蘋果新的 14 英寸和 16 英寸 MacBook Pro 2021 上市后獲得了不錯的評價,亮點包括行業領先的性能,令人印象深刻的電池續航,精美豐
Top 主站蜘蛛池模板: 元朗区| 个旧市| 呈贡县| 翁牛特旗| 曲周县| 勐海县| 民和| 高邑县| 普宁市| 正镶白旗| 富蕴县| 汝城县| 绥滨县| 徐闻县| 铜川市| 交口县| 同江市| 临西县| 池州市| 保靖县| 文安县| 固阳县| 巴青县| 葵青区| 溧阳市| 金华市| 高邑县| 漯河市| 金坛市| 富顺县| 青川县| 平邑县| 乐平市| 晋州市| 汝南县| 砀山县| 木兰县| 新营市| 怀仁县| 精河县| 信丰县|