?今天給大家介紹一個非常有效的打印字節(jié)數(shù)組的函數(shù),它的顯示方式跟Linux命令行的hexdump的輸出非常類似。
先給大家上一個效果圖:
它的輸出分為三部分:字節(jié)偏移量、16進制字節(jié)數(shù)據(jù)、ASCII碼可顯字符;
其中ASCII部分,如果對應的字節(jié)是非可顯字符,則用.代替。
立馬送上它的函數(shù)實現(xiàn):
#include
#include
int log_hexdump(const char *title, const unsigned char *data, int len)
{
char str[160], octet[10];
int ofs, i, k, d;
const unsigned char *buf = (const unsigned char *)data;
const char dimm[] = "+------------------------------------------------------------------------------+";
printf("%s (%d bytes):\r\n", title, len);
printf("%s\r\n", dimm);
printf("| Offset : 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 0123456789ABCDEF |\r\n");
printf("%s\r\n", dimm);
for (ofs = 0; ofs < (int)len; ofs += 16) {
d = snprintf( str, sizeof(str), "| %08X: ", ofs );
for (i = 0; i < 16; i++) {
if ((i + ofs) < (int)len) {
snprintf( octet, sizeof(octet), "%02X ", buf[ofs + i] );
} else {
snprintf( octet, sizeof(octet), " " );
}
d += snprintf( &str[d], sizeof(str) - d, "%s", octet );
}
d += snprintf( &str[d], sizeof(str) - d, " " );
k = d;
for (i = 0; i < 16; i++) {
if ((i + ofs) < (int)len) {
str[k++] = (0x20 <= (buf[ofs + i]) && (buf[ofs + i]) <= 0x7E) ? buf[ofs + i] : '.';
} else {
str[k++] = ' ';
}
}
str[k] = '\0';
printf("%s |\r\n", str);
}
printf("%s\r\n", dimm);
return 0;
}
int main(int argc, const char *argv[])
{
unsigned char test_buf[12] = {3 , 6, 7, 9, 234, 67, 77};
char *msg_ch = "我是一個中文字符串";
char *msg_en = "I am english string";
log_hexdump("test_buf", test_buf, sizeof(test_buf));
log_hexdump("msg_ch", msg_ch, strlen(msg_ch));
printf("msg_ch: %s\r\n\r\n\r\n", msg_ch);
log_hexdump("msg_en", msg_en, strlen(msg_en));
printf("msg_en: %s\r\n\r\n\r\n", msg_en);
return 0;
}
調用代碼也很簡單,就像上面的main函數(shù)調用一樣。
好了,這個使用的打印函數(shù)就介紹到這里,感興趣的可以研究下它的源碼,希望能夠幫助到你。
?審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
Linux
+關注
關注
87文章
11322瀏覽量
209861 -
字節(jié)
+關注
關注
0文章
40瀏覽量
13768 -
函數(shù)
+關注
關注
3文章
4338瀏覽量
62751 -
RT-Thread
+關注
關注
31文章
1296瀏覽量
40236
發(fā)布評論請先 登錄
相關推薦
RT-Thread 應用筆記 - RTC Alarm 組件的使用
RT-Thread 應用筆記 - 不正確使用LOG也會引發(fā)hard faultRT-Thread 應用筆記 - RTC Alarm 組件的使用RT-
發(fā)表于 01-25 18:18
?10次下載
RT-Thread 內核學習筆記 - 理解defunct僵尸線程
RT-Thread 內核學習筆記 - 內核對象rt_objectRT-Thread 內核學習筆記
發(fā)表于 01-25 18:19
?8次下載
RT-Thread 內核學習筆記 - 設備模型rt_device的理解
RT-Thread 內核學習筆記 - 內核對象rt_objectRT-Thread 內核學習筆記
發(fā)表于 01-25 18:19
?8次下載
RT-Thread 內核學習筆記 - 內核對象鏈表結構深入理解
RT-Thread 內核學習筆記 - 內核對象rt_objectRT-Thread 內核學習筆記
發(fā)表于 01-25 18:23
?6次下載
RT-Thread 內核學習筆記 - 內核對象初始化鏈表組織方式
RT-Thread 內核學習筆記 - 內核對象rt_objectRT-Thread 內核學習筆記
發(fā)表于 01-25 18:24
?3次下載
RT-Thread 內核學習筆記 - 內核對象操作API
RT-Thread 內核學習筆記 - 內核對象rt_objectRT-Thread 內核學習筆記
發(fā)表于 01-25 18:26
?7次下載
RT-Thread學習筆記分享
我是從2020年11月初開始學習RT-Thread實時操作系統(tǒng)的,在學習RT-Thread之前,我接觸過uCOS和FreeRTOS,但這兩個在單片機上應用的實時操作系統(tǒng),我都沒有仔細并
RT-Thread學習筆記 RT-Thread的架構概述
RT-Thread 簡介 作為一名 RTOS 的初學者,也許你對 RT-Thread 還比較陌生。然而,隨著你的深入接觸,你會逐漸發(fā)現(xiàn) RT-Thread 的魅力和它相較于其他同類型 RTOS
評論