<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>
"); //-->

博客專(zhuān)欄

EEPW首頁(yè) > 博客 > 推薦一個(gè)實(shí)用的嵌入式日志開(kāi)源項目 dbuglib

推薦一個(gè)實(shí)用的嵌入式日志開(kāi)源項目 dbuglib

發(fā)布人:xiaomaidashu 時(shí)間:2024-06-07 來(lái)源:工程師 發(fā)布文章
嵌入式開(kāi)發(fā)過(guò)程中,調試是必不可少的一個(gè)環(huán)節。怎樣調試才能快速定位代碼的問(wèn)題呢?方法有很多,今天給大家分享一款精小調試支持庫:dbuglib.概述

ulog日志記錄庫是一個(gè)精小的靜態(tài)日志記錄庫。內部很多功能均由宏定義來(lái)實(shí)現。用戶(hù)可以修改日志的級別用于過(guò)濾特定級別的日志。

文件
  • ulog.h:定義了各種日志記錄級別和日志記錄宏

  • ulog.c:提供了內存打印等接口函數

  • ASSERT.h:提供了用戶(hù)可定義的斷言宏支持

  • VS文件夾:VC上位機測試示例

  • MDK文件夾:MDK下位機測試示例

日志級別

ulog支持5種日志記錄級別,可在ulog.h文件中修改LOG_CFG_LEVE宏定義來(lái)定義日志的記錄級別。

  • G_DEBUG:調試日志級別,用來(lái)記錄最詳細的調試信息和執行步驟

  • G_TRACE:跟蹤日志級別,用來(lái)記錄重要的跟蹤信息

  • G_WARNG:警告日志級別,用來(lái)記錄一些警告信息

  • G_ERROR:錯誤日志級別,用來(lái)記錄嚴重的錯誤信息

  • G_NONE:不做任何日志記錄

示例1:將LOG_CFG_LEVE配置為G_WARNG級別,則只會(huì )顯示G_WAGNGG_ERROR兩個(gè)級別的日志記錄,其他的記錄級別較低將不被顯示 示例2:配置為G_NONE級別將禁用日志記錄功能

定義日志記錄樣式

ulog.h文件中定義了LOG_FUN宏,用戶(hù)可以對其修改來(lái)改變日志的打印樣式

// 定義打印樣式
#define LOG_FUN(LEVESTR,format, ...)      
   LOG_PRINTF("["LEVESTR"] <"__FILE__": %d"">: " format "rn",__LINE__,##__VA_ARGS__)
使用方式
    ASSERT_MSG(, );
    uLOG(G_DEBUG,,);
    uLOG_MEM(G_DEBUG, randbuff, , ,);

打印數據如下:

[G_DEBUG] <main.c: 16>: error:123
[G_DEBUG] <main.c: 17>: error:586
00000000: 29 23 BE 84 E1 6C D6 AE 52 90 49 F1 F1 BB E9 EB  )#...l..R.I.....
00000010: B3 A6 DB 3C 87 0C 3E 99 24 5E 0D 1C 06 B7 47 DE  ...<..>.$^....G.
00000020: B3 12 4D C8 43 BB 8B A6 1F 03 5A 7D 09 38 25 1F  ..M.C.....Z}.8%.
00000030: 5D D4 CB FC 96 F5 45 3B 13 0D 89 0A 1C DB AE 32  ].....E;.......2
00000040: 20 9A 50 EE 40 78 36 FD 12 49 32 F6 9E 7D 49 DC   .P.@x6..I2..}I.
00000050: AD 4F 14 F2 44 40 66 D0 6B C4 30 B7 32 3B A1 22  .O..D@f.k.0.2;."
00000060: F6 22 91 9D E1 8B 1F DA B0 CA 99 02 B9 72 9D 49  ."...........r.I
00000070: 2C 80 7E C5 99 D5 E9 80 B2 EA C9 CC 53           ,.~.........S

以上為程序的使用示例,說(shuō)明如下:

  • uLOG:指定日志級別和相應的字符串,其支持printf類(lèi)似的轉移修飾符

  • uLOG_MEM:可打印指定的內存數據,同樣需要指定日志級別,

  • ASSERT:該宏當參數為假時(shí)會(huì )停止程序,并打印顯示當前導致斷言的文件和行號

  • ASSERT_MSG:與ASSERT相同,只不過(guò)多了個(gè)字符串參數,可以顯示一些信息。

移植

該庫編寫(xiě)時(shí)使用了一些C99特性,所以編譯器必須支持C99標準。已經(jīng)在VS2015和MDK5.0中測試,均可正常工作。移植時(shí)必須定義LOG_PRINTF宏到實(shí)際的打印函數,還必須定義LOG_PUT_CHAR宏到實(shí)際的字符輸出函數:

// 字符輸出函數
#define LOG_PUT_CHAR(C) putchar(C)
// 日志記錄接口
#define LOG_PRINTF(format, ...) printf(format, ##__VA_ARGS__)


*博客內容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀(guān)點(diǎn),如有侵權請聯(lián)系工作人員刪除。



關(guān)鍵詞: 嵌入式

相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>