习惯了拿来主义,有时候遇到问题之后总是考虑是否有库或者现成的东西可用。结果,有些很简单的问题处理起来忘掉了最基础的技巧。
尝试将十六进制的字符串转换成数字,技巧其实很多。为了练手,利用ASCII码表的顺序关系自己做了一个简单的小函数。
实现功能:
- 合理的单个十六进制字符转换成数字;
- 合理的两位十六进制字符串转数字;
根据自己的设计,测试如下:
测试结果如下:
最后,附加我的全部代码如下:
#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;
}