天天看點

c語言uint8 t轉字元串,C語言中uint8_t*轉char*

這主要是在列印中有需求

示例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;

}