转载自: 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