这主要是在打印中有需求
示例1
这个写的有点傻,总之还是需要逐一去判断,然后将一个byte数据按照4bit拆开,再转成ASCII码显示
#define OTP_SIZE (255)
char tmp_opt[OTP_SIZE*2+1]={0};
for(int i=0;i
{
if((sd->otp_data[i] >> 4)<=0x09)
{
tmp_opt[2*i] = (sd->otp_data[i] >> 4) + '0';
}
else if((sd->otp_data[i] >> 4)<=0x0F)
{
tmp_opt[2*i] = (sd->otp_data[i] >> 4)+ 'A' - 9;
}
if((sd->otp_data[i] & 0x0F)<=0x09)
{
tmp_opt[2*i+1] = (sd->otp_data[i] & 0x0F) + '0';
}
else if((sd->otp_data[i] & 0x0F)<=0x0F)
{
tmp_opt[2*i+1] = (sd->otp_data[i] & 0x0F) + 'A' - 9;
}
}
LOGD("opt: %s\n",tmp_opt);
示例2
这是个进阶的版本
int HextoChar(uint8_t *u8, uint8_t len, char *ch)
{
uint8_t tmp = 0x00;
for (int i = 0; i < len; i++)
{
for (int j = 0; j < 2; j++)
{
tmp = (*(u8 + i) >> 4) * (1 - j) + (*(u8 + i) & 0x0F) * j;
if (tmp >= 0 && tmp <= 9)
{
ch[2 * i + j] = tmp + '0';
}
else if (tmp >= 0x0A && tmp <= 0x0F)
{
ch[2 * i + j] = tmp - 0x0A + 'A';
}
}
}
return 0;
}