数据转换-整数字节数组
0. 在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务
1 参考《GMT 0009-2012 SM2密码算法使用规范》第6节“数据转换” 在utils.h和utils.c中完成整数与8位字节串的转换功能
2 并写出测试代码测试上述函数
3 提交代码(或代码链接)和运行结果
1 参考《GMT 0009-2012 SM2密码算法使用规范》第6节“数据转换” 在utils.h和utils.c中完成整数与8位字节串的转换功能
代码部分如下:
utils.h
#ifndef _UTIL_H_
#define _UTIL_H_
//char Hex2Char(int i);
//int Char2Hex(char c);
int Hex2Char(int fromi,char * toc);
int Char2Hex(char fromc,int * toi);
int Bitstr2ByteArr(char * bs,char * ba);
int ByteArr2Bitstr(char * ba,char * bs);
int Int2ByteArr(int i,char * ba);
int ByteArr2Int(char * ba,int * i);
#endif
utils.c
#include<stdio.h>
#include"utils.h"
#include<string.h>
int Hex2Char(int fromi,char *toc)
{
if(fromi>=0&&fromi<=9)
{
*toc= fromi+'0';
}
else if(fromi>=10&&fromi<=15)
{
*toc = fromi+'A'-10;
}
else
{
printf("输入的16进制数据不正确!");
}
return 0;
}
int Char2Hex(char fromc,int *toi)
{
if(fromc>='0'&& fromc<='9')
{
*toi= fromc-'0';
}
else if(fromc>='A'&& fromc<='F')
{
*toi= fromc-'A'+10;
}
else
{
printf("输入的16进制字符不正确");
}
return 0;
}
int INT2ByteArr(int i,char *ba){
int j;
int a;
int sum=0;
int k=i;
for(j=0;;j++)
{
k=k/16;
if(k!=0)
sum++;
else
break;
}
for(j=sum;j>=0;j--){
a = i%16;
Hex2Char(a,&ba[j]);
i=i/16;
}
ba[sum+1]='';
}
int ByteArr2INT(char *ba,int *i)
{
int len;
int j;
int n=0;
*i=0;
len = strlen(ba);
for(j=0;j<len;j++)
{
Char2Hex(ba[j],&n);
//printf("%d
",n);
*i=(*i)*16+n;
}
}
main.c
#include<stdio.h>
#include"utils.h"
int main(){
//把整型数字转化为字节数组
int p;
char bytearr[100];
printf("请输入一个整型数字
");
scanf("%d",&p);
printf("把整型数转化为字节数组
");
INT2ByteArr(p,bytearr);
printf("字节数组为%s
",bytearr);
//把字节数组转化为整型数字
char barr[100];
int h;
printf("请输入一个字节数组:");
scanf("%s",barr);
printf("把字节数组转化为整型数字:");
ByteArr2INT(barr,&h);
printf("%d
",h);
}
3 提交代码(或代码链接)和运行结果
运行结果如下: