习惯了拿来主义,有时候遇到问题之后总是考虑是否有库或者现成的东西可用。结果,有些很简单的问题处理起来忘掉了最基础的技巧。

         尝试将十六进制的字符串转换成数字,技巧其实很多。为了练手,利用ASCII码表的顺序关系自己做了一个简单的小函数。

         实现功能:

  1. 合理的单个十六进制字符转换成数字;
  2. 合理的两位十六进制字符串转数字;

根据自己的设计,测试如下:

407_C语言十六进制字符串转数字_经验分享

         测试结果如下:

407_C语言十六进制字符串转数字_经验分享_02

         最后,附加我的全部代码如下:

#include "stdio.h"
#include "stdint.h"

char s1[] = "0123456789ABCDEF";
char s2[] = "0123456789abcdef";

uint8_t char2u8(char c)
{
    if ((c >= 'a') && (c <= 'f'))
    {
        c -= 32;
    }

    if ((c >= 'A') && (c <= 'F'))
    {
        return c - 'A' + 10;
    }
    else
    {
        return c - '0';
    }
}

uint8_t hex_dchar2u8(char *p_c)
{
    return (char2u8(p_c[0]) << 4) + char2u8(p_c[1]);
}

int main(void)
{
    int i = 0;

    for (i = 0; i < sizeof(s1) - 1; i++)
    {
        printf("%d,", char2u8(s1[i]));
    }

    printf("\n");

    for (i = 0; i < sizeof(s2) - 1; i++)
    {
        printf("%d,", char2u8(s2[i]));
    }

    printf("\n");

    for (i = 0; i < (sizeof(s1) - 1) / 2; i++)
    {
        printf("%0d,", hex_dchar2u8(&s1[2 * i]));
    }

    printf("\n");

    for (i = 0; i < (sizeof(s1) - 1) / 2; i++)
    {
        printf("%02x,", hex_dchar2u8(&s1[2 * i]));
    }

    return 0;
}