转载自: https://blog.csdn.net/yu_yuan_1314/article/details/12705237
一、Hex编码简介
Hex 全称 是Intel HEX。Hex文件是由一行行符合Intel HEX文件格式的文本所构成的ASCII文本文件。在Intel HEX文件中,每一行包含一个HEX记录。这些记录由对应机器语言码和/或常量数据的十六进制编码数字组成。
那么Hex编码是什么呢?就是将数据转化成符合Intel HEX文件中的数据格式的编码方式。举一个简单的例子,如下:
99、105、224,7
编码之后的数据为:“6369e007”,是一个字符串。
二、Hex编码与解码实现
static const char hex_table_uc[16] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; static const char hex_table_lc[16] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' }; char *encodeToHex(char *buff, const uint8_t *src, int len, int type) { int i; const char *hex_table = type ? hex_table_lc : hex_table_uc; for(i = 0; i < len; i++) { buff[i * 2] = hex_table[src[i] >> 4]; buff[i * 2 + 1] = hex_table[src[i] & 0xF]; } buff[2 * len] = ''; return buff; } uint8_t *decodeFromHex(uint8_t *data, const char *src, int len) { size_t outLen = len / 2; uint8_t *out = data; uint8_t accum = 0; for (size_t i = 0; i < len; ++i) { char c = src[i]; unsigned value; if (c >= '0' && c <= '9') { value = c - '0'; } else if (c >= 'a' && c <= 'f') { value = c - 'a' + 10; } else if (c >= 'A' && c <= 'F') { value = c - 'A' + 10; } else { return NULL; } accum = (accum << 4) | value; if (i & 1) { *out++ = accum; accum = 0; } } return data; }
一个在线Hex编/解码网站: www.107000.com/T-Hex
最新评论