www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 電子電路開發(fā)學(xué)習(xí)
[導(dǎo)讀]在嵌入式開發(fā)中,調(diào)試代碼的方法有很多,比如使用調(diào)試器在線調(diào)試、借助一些測(cè)量?jī)x器、輸出調(diào)試日志等方式。沒(méi)有哪種方法是最好的調(diào)試方法,實(shí)際開發(fā)中需要根據(jù)實(shí)際情況借助不同的方法進(jìn)行調(diào)試。但在一些稍微大點(diǎn)的項(xiàng)目中,輸出調(diào)試日志卻是比較好的調(diào)試方法。

交心

在我們嵌入式開發(fā)中,調(diào)試代碼的方法有很多。比如使用調(diào)試器在線調(diào)試、借助一些測(cè)量?jī)x器、輸出調(diào)試日志等方式。

沒(méi)有哪種方法是最好的調(diào)試方法,實(shí)際開發(fā)中需要根據(jù)實(shí)際情況借助不同的方法進(jìn)行調(diào)試。但是,在一些稍微大點(diǎn)的項(xiàng)目中,輸出調(diào)試日志卻是比較好的調(diào)試方法。

輸出日志可以比較隨意,想輸出什么就輸出什么,但是也得注意兩個(gè)點(diǎn):

一是輸出的日志盡量整潔明了,因?yàn)槿绻罩旧晕⒍嘁稽c(diǎn),看起來(lái)就會(huì)很亂,很擾心;

二是方便打開/關(guān)閉日志相關(guān)代碼,程序調(diào)試階段打開,方便定位問(wèn)題,程序發(fā)布階段關(guān)閉,可節(jié)省不必要地資源開銷。

最近在做Linux方面的開發(fā),整天分析日志,有點(diǎn)體會(huì)。順便也寫點(diǎn)日志筆記分享給大家:

站在巨人的肩膀上

網(wǎng)絡(luò)上有很多現(xiàn)成的日志庫(kù),簡(jiǎn)單移植一下就可以使用。這里分享一個(gè)常用的日志庫(kù)—— EasyLogger。

碼云倉(cāng)庫(kù)及介紹地址:

https://gitee.com/Armink/EasyLogger?_from=gitee_search#easylogger

1、EasyLogger介紹

EasyLogger是一款超輕量級(jí)(ROM<1.6K, RAM<0.3K)、高性能的C/C++日志庫(kù),非常適合對(duì)資源敏感的軟件項(xiàng)目,例如:IoT產(chǎn)品、可穿戴設(shè)備、智能家居等等。

2、EasyLogger特性

  • 支持用戶自定義輸出方式(例如:終端、文件、數(shù)據(jù)庫(kù)、串口、485、Flash...);
  • 日志內(nèi)容可包含級(jí)別、時(shí)間戳、線程信息、進(jìn)程信息等;
  • 日志輸出被設(shè)計(jì)為線程安全的方式,并支持 異步輸出緩沖輸出模式;
  • 支持多種操作系統(tǒng)(RT-Thread、UCOS、Linux、Windows...),也支持裸機(jī)平臺(tái);
  • 日志支持 RAW格式,支持 hexdump;
  • 支持按 標(biāo)簽級(jí)別、 關(guān)鍵詞進(jìn)行動(dòng)態(tài)過(guò)濾;
  • 各級(jí)別日志支持不同顏色顯示;
  • 擴(kuò)展性強(qiáng),支持以插件形式擴(kuò)展新功能。

3、EasyLogger的嘗試

該開源項(xiàng)目提供了豐富的demo,有stm32裸機(jī)的demo,有RT-Thread的demo、有Windows下的demo、有Linux下的demo。這里我們跑一下stm32裸機(jī)的demo。


進(jìn)行初始化及一些設(shè)置之后就可以調(diào)用其給我們用戶提供的日志打印接口log_a、log_e、log_w等來(lái)輸出日志信息,我們使用日志庫(kù)也主要使用的是這幾個(gè)接口,其它輔助功能有興趣的朋友可自行學(xué)習(xí)使用。

4、EasyLogger的移植、剖析

想要對(duì)EasyLogger進(jìn)行深入學(xué)習(xí)可查閱項(xiàng)目的readme文件、源碼閱讀及如下兩篇文章:

【開源解讀】一款輕量級(jí)C日志庫(kù)-EasyLogger

第3期 | EasyLogger,一款輕量級(jí)且高性能的日志庫(kù)

自己動(dòng)手,豐衣足食

網(wǎng)絡(luò)上的一些日志庫(kù)的功能過(guò)于強(qiáng)大,有時(shí)候我們用不上一些高級(jí)的功能,沒(méi)必要大動(dòng)干戈移植一個(gè)日志庫(kù)。

這時(shí)候我們可以通過(guò)簡(jiǎn)單的幾行代碼實(shí)現(xiàn)我們自己的日志打印格式。其實(shí)之前也有簡(jiǎn)單分享過(guò)打印相關(guān)的技術(shù)筆記:C語(yǔ)言、嵌入式中幾個(gè)非常實(shí)用的宏技巧

摘選那篇筆記的代碼:

左右滑動(dòng)查看全部代碼>>>

#define??DEBUG???1??

#if?DEBUG
??#define?DBG_PRINTF(fmt,?args...)??\
??do\
??{\
????printf("<>?",?__FILE__,?__LINE__,?__FUNCTION__);\
????printf(fmt,?##args);\
??}while(0)

#else
??#define?DBG_PRINTF(fmt,?args...)???
#endif

我們拿來(lái)修改一下,下面分享兩種簡(jiǎn)單的日志輸出方式:

1、分模塊打印

給各個(gè)模塊加上宏打印開關(guān)。在調(diào)試時(shí)可以通過(guò)宏開關(guān)先屏蔽掉沒(méi)有問(wèn)題的模塊的日志信息,減少日志地輸出,方便專注于有問(wèn)題的模塊分析。

直接上代碼吧。。。

(1)main.c

左右滑動(dòng)查看全部代碼>>>

/*?
demo:?分模塊打印日志
公眾號(hào):嵌入式大雜燴
*/

#include?
#include?"module1.h"
#include?"module2.h"

int?main(void)
{
?module1_print();
?module2_print();
?return?0;
}

(2)mylog.h

左右滑動(dòng)查看全部代碼>>>

#define?__MYLOG_H__

#ifdef?__cplusplus
extern?"C"?{
#endif

#include?

/*?各模塊日志開關(guān)?*/
#define??MODULE1_LOG_SWITCH??1
#define??MODULE2_LOG_SWITCH??1

/*?日志統(tǒng)一輸出的格式?*/
#define?DBG_PRINTF(fmt,?args...)??\
do\
{\
?printf("<>?",?__FILE__,?__LINE__,?__FUNCTION__);\
?printf(fmt,?##args);\
}while(0)


#ifdef?__cplusplus
}
#endif

#endif?/*?__MYLOG_H__?*/

(3)module1.c

左右滑動(dòng)查看全部代碼>>>

#include?"module1.h"

#if?MODULE1_LOG_SWITCH
#define?LOG_MODULE1(fmt,?args...)???DBG_PRINTF(fmt,?##args)??
#else
#define?LOG_MODULE1(fmt,?args...)?
#endif

void?module1_print(void)
{
?LOG_MODULE1("hello?module1\n");
}

(4)module1.h

左右滑動(dòng)查看全部代碼>>>

#ifndef?__MODEL1_H__
#define?__MODEL1_H__

#ifdef?__cplusplus
extern?"C"?{
#endif

#include?"mylog.h"

void?module1_print(void);

#ifdef?__cplusplus
}
#endif

#endif?/*?__MODEL1_H__?*/

(5)module2.c

左右滑動(dòng)查看全部代碼>>>

#include?"module2.h"

#if?MODULE2_LOG_SWITCH
#define?LOG_MODULE2(fmt,?args...)???DBG_PRINTF(fmt,?##args)??
#else
#define?LOG_MODULE2(fmt,?args...)?
#endif

void?module2_print(void)
{
?LOG_MODULE2("hello?module2\n");
}

(6)module2.h

左右滑動(dòng)查看全部代碼>>>

#ifndef?__MODEL2_H__
#define?__MODEL2_H__

#ifdef?__cplusplus
extern?"C"?{
#endif

#include?"mylog.h"

void?module2_print(void);

#ifdef?__cplusplus
}
#endif

#endif?/*?__MODEL2_H__?*/

通過(guò)模塊日志開關(guān)可以打開/關(guān)閉各模塊日志打印接口。這里的demo只拿兩個(gè)模塊作為例子,可模仿這兩個(gè)模塊拓展其它模塊。

編譯、運(yùn)行:

2、分級(jí)打印

分級(jí)打印是日志庫(kù)里常用的方式,比如上面的EasyLogger日志庫(kù)的分級(jí)打印實(shí)現(xiàn)方式:

這也是EasyLogger的核心部分。

我們可以把這一部分抽出來(lái)修改一下:

(1)main.c

左右滑動(dòng)查看全部代碼>>>

/*??
demo:分級(jí)打印日志
公眾號(hào):嵌入式大雜燴
*/

#include?"mylog.h"

int?main(void)
{
????LOG_A("Hello?world");
????LOG_E("Hello?world");
????LOG_W("Hello?world");
????LOG_I("Hello?world");
????LOG_D("Hello?world");
????LOG_V("Hello?world");
?return?0;
}

(2)mylog.h

左右滑動(dòng)查看全部代碼>>>

#ifndef?__MYLOG_H__
#define?__MYLOG_H__

#ifdef?__cplusplus
extern?"C"?{
#endif

#include?

/*?日志級(jí)別?*/
#define?ELOG_LVL_ASSERT????0
#define?ELOG_LVL_ERROR?????1
#define?ELOG_LVL_WARN??????2
#define?ELOG_LVL_INFO??????3
#define?ELOG_LVL_DEBUG?????4
#define?ELOG_LVL_VERBOSE???5

/*?設(shè)置日志級(jí)別?*/
#define?ELOG_OUTPUT_LVL????ELOG_LVL_VERBOSE

/*?斷言(Assert)??*/
#define?LOG_A(args,...)\
do{\
????if?(ELOG_OUTPUT_LVL?>=?ELOG_LVL_ASSERT)\
????{\
????????printf("[A/%s?Line:%.4d]?"?args?"\n",?__FILE__,?__LINE__,?##__VA_ARGS__);\
????}\
}while(0)


/*?錯(cuò)誤(Error)?*/
#define?LOG_E(args,...)\
do{\
????if?(ELOG_OUTPUT_LVL?>=?ELOG_LVL_ASSERT)\
????{\
????????printf("[E/%s?Line:%.4d]?"?args?"\n",?__FILE__,?__LINE__,?##__VA_ARGS__);\
????}\
}while(0)


/*?警告(Warn)?*/
#define?LOG_W(args,...)\
do{\
????if?(ELOG_OUTPUT_LVL?>=?ELOG_LVL_WARN)\
????{\
????????printf("[W/%s?Line:%.4d]?"?args?"\n",?__FILE__,?__LINE__,?##__VA_ARGS__);\
????}\
}while(0)


/*?信息(Info)?*/
#define?LOG_I(args,...)\
do{\
????if?(ELOG_OUTPUT_LVL?>=?ELOG_LVL_INFO)\
????{\
????????printf("[I/%s?Line:%.4d]?"?args?"\n",?__FILE__,?__LINE__,?##__VA_ARGS__);\
????}\
}while(0)

?
/*?調(diào)試(Debug)?*/
#define?LOG_D(args,...)\
do{\
????if?(ELOG_OUTPUT_LVL?>=?ELOG_LVL_DEBUG)\
????{\
????????printf("[D/%s?Line:%.4d]?"?args?"\n",?__FILE__,?__LINE__,?##__VA_ARGS__);\
????}\
}while(0)

?
/*?詳細(xì)(Verbose)?*/
#define?LOG_V(args,...)\
do{\
????if?(ELOG_OUTPUT_LVL?>=?ELOG_LVL_VERBOSE)\
????{\
????????printf("[V/%s?Line:%.4d]?"?args?"\n",?__FILE__,?__LINE__,?##__VA_ARGS__);\
????}\
}while(0)


#ifdef?__cplusplus
}
#endif

#endif?/*?__MYLOG_H__?*/

編譯、運(yùn)行:


以上就是本次的筆記分享,如有錯(cuò)誤,歡迎指出,感謝閱讀!期待大家的轉(zhuǎn)發(fā),大家的轉(zhuǎn)發(fā)也是我持續(xù)更新的動(dòng)力。

猜你喜歡

OpenBLT Bootloader的使用分享

C語(yǔ)言對(duì)象編程第一彈:封裝與抽象



免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉