Q: 调试程序的时候,经常需要对传入的连续地址空间或数组进行打印,常规做法是起一个for循环,在每次循环中调用printf依次打印每个数组下标的值。 就像这样:
char Buf[99] = {0};
for(int i = 0; i < 99; i++)
{
printf("Buf[%d] : %X \r\n", i, Buf[i]);
}
这样做的弊端是,面对不同长度的数组时,需要针对性更改for循环的次数。而且当printf有系统级封装的时候,会打印多余的信息和换行。而且每次都要手写for循环。
A:一劳永逸,封装了一个接口 ,需要打印的时候调用outputDynamicBuffer 就可以了
/*
* =====================================================================================
*
* Author: YZH
*
* =====================================================================================
*/
#include <stdio.h>
#define FAKEBUF_LEN 10
#define OUTPUTBUF_LEN 1024
#define SNPRINTF_ONCE_LEN 4 //(单字节转换为字符串(2 byte) + snprintf追加的结束符(1 byte) + 空格(1 byte))
void outputDynamicBuffer(char *srcBuf, int srcBufLen);
int main()
{
char fakeBuf[FAKEBUF_LEN] = {0,1,2,3,4,5,6,7,8,9};
outputDynamicBuffer(fakeBuf, 10);
return 0;
}
/**
* @description: 动态输出不同长度值(16进制)
* @param {char} *srcBuf 要输出的源buf首地址
* @param {int} srcBufLen 要输出的源buf长度
* @return {*}
*/
void outputDynamicBuffer(char *srcBuf, int srcBufLen)
{
if(0 == srcBufLen || NULL == srcBuf)
{
printf("Illega Input Parameter !!! \r\n");
return;
}
int ret = 0; //接收函数执行结果
char outputBuf[OUTPUTBUF_LEN] = {0}; //接收连续snprintf后的字符串
for(int i = 0; i < srcBufLen; i++)
{
//首次执行,首地址为0
//"%02X " 输出大写的16进制数,不足两位时首位补0,最后加一空格
//SNPRINTF_ONCE_LEN*i - i*1 每次snprintf时,要把上一次snprintf生成的结束符覆盖掉(第一次除外)
0 == i? (ret = snprintf(&outputBuf[0], SNPRINTF_ONCE_LEN, "%02X ", srcBuf[i]))\
: (ret = snprintf(&outputBuf[SNPRINTF_ONCE_LEN*i - i*1], SNPRINTF_ONCE_LEN, "%02X ", srcBuf[i]));
0 == ret? printf("Warning!!! ret = %d. i = %d .\r\n", ret, i):1;
}
printf("%s. srcBufLen = %d. Buf:%s .\r\n", __func__, srcBufLen, outputBuf);
}
实测非~常~好~用~