最近專案要用到這個功能,于是花了點時間自己寫了一套,個人感覺比較好用,分享出來:
/** @fn u16 hex_to_str(u8 *pAscii,u8 *pHex,u16 unStrLen)
* @brief hex陣列轉字串
* @param pAscii:字串
* @param pHex:陣列
* @param unHexLen:陣列長度
* @return 轉換結果 0:失敗,其他:字串長度
* @note 轉換后的字串字符全部大寫
*/
u16 hex_to_str(u8 *pAscii, u8 *pHex, u16 unHexLen) {
u8 ucTmp;
u16 i;
u8 *pStr = pAscii;
for (i = 0; i < unHexLen; i++) {
if (!pHex || !pStr)
return 0;
ucTmp = (pHex[i] & 0xF0) >> 4;
if (ucTmp < 10) {
ucTmp += '0';
} else {
ucTmp = ucTmp - 10 + 'A';
}
*pStr++ = ucTmp;
ucTmp = (pHex[i] & 0x0F);
if (ucTmp < 10) {
ucTmp += '0';
} else {
ucTmp = ucTmp - 10 + 'A';
}
*pStr++ = ucTmp;
}
//DEBUG_INFO("\n%s len[%d]\n", pAscii, 2 * unHexLen);
return (2 * unHexLen);
}
/** @fn u16 str_to_hex(u8 *pAscii,u8 *pHex,u16 unStrLen)
* @brief 字串轉hex陣列
* @param pAscii:字串
* @param pHex:陣列
* @param unStrLen:字串長度
* @return 轉換結果 0:失敗,其他:陣列長度
* @note 字串長度必須為2的倍數,不區分大小寫
*/
u16 str_to_hex(u8 *pAscii, u8 *pHex, u16 unStrLen) {
u8 ucByte;
u8 ucTmp;
u16 i;
if (0 != unStrLen % 2)
return 0;
for (i = 0; i < unStrLen / 2; i++) {
ucTmp = *pAscii++;
if (ucTmp >= '0' && ucTmp <= '9') {
ucTmp -= '0';
} else if (ucTmp >= 'A' && ucTmp <= 'F') {
ucTmp = ucTmp + 10 - 'A';
} else if (ucTmp >= 'a' && ucTmp <= 'f') {
ucTmp = ucTmp + 10 - 'a';
} else {
return 0;
}
ucByte = (ucTmp << 4);
ucTmp = *pAscii++;
if (ucTmp >= '0' && ucTmp <= '9') {
ucTmp -= '0';
} else if (ucTmp >= 'A' && ucTmp <= 'F') {
ucTmp = ucTmp + 10 - 'A';
} else if (ucTmp >= 'a' && ucTmp <= 'f') {
ucTmp = ucTmp + 10 - 'a';
} else {
return 0;
}
ucByte += ucTmp;
pHex[i] = ucByte;
//os_printf("%02x ",pHex[i]);
}
//os_printf("\nlen[%d]\n",unStrLen / 2);
return (unStrLen / 2);
}
By Urien 2021年6月9日 21:48:16
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/286831.html
標籤:其他
