Hex编码与解码

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/lyuan1314/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] = '\0';
   
    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;
}

展开阅读全文

没有更多推荐了,返回首页