C语言16进制字符串转数字

Posted 车子 chezi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言16进制字符串转数字相关的知识,希望对你有一定的参考价值。

假设有一个十六进制字符串,“99AD1B5226A37E3E058E3B8E27C2C666”,如何把它按照字节来切分,然后转成整型?也就是说转换成 0x99, 0xAD, 0x1B, …

代码实现

C 语言参考代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char *key = "99AD1B5226A37E3E058E3B8E27C2C666";
void main(void)
{
    if(strlen(key) & 1){
        printf("key 的长度是奇数!");
        return;
    }
    
    char byte[3] = {0};
    char *p = key;
    char *endptr;
    unsigned int res;
    
    for(int i = 0; i < strlen(key); i += 2){
        memcpy(byte, &key[i], 2);
        res = strtol(byte, &endptr, 16);
        printf("%02x ", res);
    }
    printf("\\n");
}

测试结果:

99 ad 1b 52 26 a3 7e 3e 05 8e 3b 8e 27 c2 c6 66

说明:

  1. 代码中要求待转换字符串的长度是偶数,如果是奇数,可以手动补零
  2. 用到的关键函数是 strtol,它的原型是
long int strtol (const char* str, char** endptr, int base);

strtol 介绍

long int strtol (const char* str, char** endptr, int base);

【参数说明】
str 为要转换的字符串,endstr 为第一个不能转换的字符的指针,base 为字符串 str 所采用的进制。
【函数说明】
strtol() 会扫描参数 str 字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过 isspace() 函数来检测),直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时(’\\0’)结束转换,并将结果返回。

两点注意:

  1. 当 base 的值为 0 时,默认采用 10 进制转换,但如果遇到 ‘0x’ / ‘0X’ 前置字符则会使用 16 进制转换,遇到 ‘0’ 前置字符则会使用 8 进制转换。
  2. 若endptr 不为NULL,则会将遇到的不符合条件而终止的字符指针由 endptr 传回;若 endptr 为 NULL,则表示该参数无效,或不使用该参数。

【返回值】
返回转换后的长整型数;如果不能转换或者 str 为空字符串,那么返回 0(0L);如果转换得到的值超出 long int 所能表示的范围,函数将返回 LONG_MAX 或 LONG_MIN(在 limits.h 头文件中定义),并将 errno 的值设置为 ERANGE。

代码重构

为了方便使用,可以把这个小功能提炼成一个函数,我给它起名为 hex_string_to_u8。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef unsigned char u8;


int hex_string_to_u8(const char *hex_str, char *out)
{
    if(strlen(hex_str) & 1){
        printf("字符串的长度是奇数!");
        return -1;
    }
    
    char byte[3] = {0};
    const char *p = hex_str;
    int j = 0;
       
    for(int i=0; i<strlen(hex_str); i+=2){
        memcpy(byte, &p[i], 2);
        out[j++] = strtol(byte, NULL, 16);
    }   
    return 0;
}

void hexdump(void *data, int size){
    if (size <= 0) return;
    int i;
    for (i=0; i<size;i++){
        printf("%02X ", ((u8 *)data)[i]);
    }
    printf("\\n");
}


void main(void)
{
	char *key = "99AD1B5226A37E3E058E3B8E27C2C666";
    char res[16] = {0};
    hex_string_to_u8(key, res);
    hexdump(res, 16);
}


参考资料:
C语言strtol()函数:将字符串转换成long(长整型数)_C语言中文网

以上是关于C语言16进制字符串转数字的主要内容,如果未能解决你的问题,请参考以下文章

c语言 输入16进制形式的字符串转换成16进制

c语言怎么字符串和16进制转码 汉字转16进制如“我”转换成 “0xe68891”; 16进制转汉字“0xe68891”转 我

C语言如何把11位16进制字符串转成16进制数?

C语言如何把11位16进制字符串转成16进制数?

C语言字符串转为16进制字符串

C语言字符串转为16进制字符串