有3种方式实现,其中两种是使用系统函数,另一种是直接自己编写。
使用系统函数实现要加入#include <stdlib.h>,自己编写则不需要这个头文件。
下面的代码就是3种方式的实现,包括2位的整数和任意整数(2的31次方以内)都可以。可自己选择需要的实现方式。
利用系统函数有
1. char * itoa ( int value, char * str, int base );value是要转化的数字,str是转化后的字符串存储的位置,base是进制数(但是这个函数不是标准C函数,有些编译器是不支持的!)。所以代码可以为:
char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度
char * inttohex( int aa)
{
itoa (aa, buffer, 16);
return (buffer);
}
|
2. sprintf(str,"%x",value);str是转化存储的位置,%x表示十六进制格式,value是要转化的数字。所以代码可以为:
char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度
char * inttohex( int aa)
{
sprintf (buffer, "%x" , aa);
return (buffer);
}
|
3. 自己编写
如果参数只要两位数的整数,那么很简单。代码如下:
char buffer [3]; //用于存放转换好的十六进制字符串。由于只要支持2位整数,所以长度3即可
char * inttohex( int aa)
{
if (aa / 16 < 10) //计算十位,并转换成字符
buffer[0] = aa / 16 + '0' ;
else
buffer[0] = aa / 16 - 10 + 'A' ;
if (aa % 16 < 10) //计算个位,并转换成字符
buffer[1] = aa % 16 + '0' ;
else
buffer[1] = aa % 16 - 10 + 'A' ;
buffer[2] = '' ; //字符串结束标志
return (buffer);
}
|
如果参数是任意整数,由于计算方法是每次都除以16和对16取余数,余数以倒序的顺序排列就是结果,所以最佳方法是用递归函数(当然循环也可以,但需要最后再进行倒序)。递归代码如下:
char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度
char * inttohex( int aa)
{
static int i = 0;
if (aa < 16) //递归结束条件
{
if (aa < 10) //当前数转换成字符放入字符串
buffer[i] = aa + '0' ;
else
buffer[i] = aa - 10 + 'A' ;
buffer[i+1] = '' ; //字符串结束标志
}
else
{
inttohex(aa / 16); //递归调用
i++; //字符串索引+1
aa %= 16; //计算当前值
if (aa < 10) //当前数转换成字符放入字符串
buffer[i] = aa + '0' ;
else
buffer[i] = aa - 10 + 'A' ;
}
return (buffer);
}
#include <stdio.h>
#include <stdlib.h>
|
最后测试代码如下(以sprintf为例,其余只要替换inttohex函数中的代码内容即可):
#include <stdio.h>
#include <stdlib.h>
char buffer [33]; //用于存放转换好的十六进制字符串,可根据需要定义长度
char * inttohex( int aa)
{
sprintf (buffer, "%x" , aa);
return (buffer);
}
int main ()
{
int num;
char * hex_str;
printf ( "Enter a number: " );
scanf ( "%d" ,&num);
hex_str = inttohex (num);
printf ( "Hexadecimal number: %sH\n" , hex_str);
return 0;
}
char
buffer [33];
//用于存放转换好的十六进制字符串,可根据需要定义长度