急求十六进制转浮点数C程序!!!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了急求十六进制转浮点数C程序!!!相关的知识,希望对你有一定的参考价值。

ieee754标准规定了单精度的浮点数在计算机的内存中以4个字节(也就是8个十六进制数)的形式存储,其具体的标准什么的我都已经知道了,现在我需要一个C程序能够实现输入一个8位的16进制数,就能将其转化为对应的浮点数并输出!
我已经试了好多编法,都不行(如附图所示,编译器是用的turbo C++3.0),其中我觉得最靠谱的利用指针和强制类型转化的方法也不行,可能是我的水平太次了,真诚求助各位C语言高手,这是我毕业设计的一部分,如若能成功帮我解决这个问题,必有重谢!

楼主你好.
楼上的解决方式是很对的。
这个问题的解决需要这样的一个思想:将需要转换的数值的地址取出,赋值给一个“想要转换成的”数据类型的地址(也就是指针),然后取需要的内存单元中的内容就可以了
例如对一个赋了值的十六进制的变量n,需要转换成float型的,就是先取其地址&n,赋给一个float型的指针,也就是(float*)&n,然后取指针的内容*(float)&n就可以了。
需要注意的是,这个方法只适用于所需转换的数据在内存中所占大小与需要转换成的数据类型在内存中所占大小相同的情况(如VC6中,float型数据占4个字节,而每个字节是两位十六进制数,4个字节也就是八位十六进制数,正好等于你需要转换的十六进制数的位数,故此方法可行)
希望我的回答能帮到你~!
以下附上参考程序段:
#include <stdio.h>

float Hex_To_Decimal(unsigned char *Byte,int num)//十六进制到浮点数

// char cByte[4];//方法一
// for (int i=0;i<num;i++)
//
// cByte[i] = Byte[i];
//
//
// float pfValue=*(float*)&cByte;
//return pfValue;

return *((float*)Byte);//方法二


long FloatTohex(float HEX)//浮点数到十六进制转换1

return *( long *)&HEX;


void FloatToByte(float floatNum,unsigned char* byteArry)////浮点数到十六进制转换2

char* pchar=(char*)&floatNum;
for(int i=0;i<sizeof(float);i++)

*byteArry=*pchar;
pchar++;
byteArry++;




void main()


unsigned char floatToHex[4];
unsigned char hexbyte[4]=0xd0,0x0f,0x49,0x40;//传输数据为3d cc cc cd,0xcd,0xCC,0xCC,0x3D,40490fd0

float Hdecimal=0.0;
float flh=0.4;
Hdecimal=Hex_To_Decimal(hexbyte,sizeof(hexbyte));//十六进制转换为浮点数
printf("\n 浮点数为:\n %f\n",Hdecimal);

long hX=FloatTohex(Hdecimal);//浮点数转换为十六进制一

printf("\n正序十六进制值:\n %f=%X \n",Hdecimal,hX);//正序显示

FloatToByte(Hdecimal,floatToHex);//浮点数转为十六进制二

printf("\n倒序十六进制:\n%f=%x %x %x %x\n",Hdecimal,floatToHex[0],floatToHex[1],floatToHex[2],floatToHex[3] );//倒序显示
参考技术A #include<stdio.h>
int main()

long int n; //Tc3.0好像是16位编译器
printf("输入8位16进制数:");
scanf("%x",&n);
printf("%f\n",*((float*)&n));
return 0;



运行结果

输入8位16进制数:40490fd0
3.141590
Press any key to continue追问

这个程序代码你试了吗?有用吗?我在turbo C++3.0试了,不行呀,结果是-0.00000,你用的什么编译器呀?

追答

我用Dev c++和 vc2010 都运行过这个,没问题的,TC3.0太老了,都快20年了

Tc3.0的scanf()函数可能不支持%x输入格式,可以以字符串方式解决
#include
#include
int main()

char hexstr[9];
char *pc=hexstr;
long int n=0;
float * pf=(float*)&n ;
printf("n=");
gets(hexstr);
while(*pc)

if('0'<=*pc&&*pc<='9')
*pc=*pc-'0';
if('A'<=*pc&&*pc<='F')
*pc= 10+*pc-'A';
if('a'<=*pc&&*pc<='f')
*pc= 10+*pc-'a';
n=n*16+*pc;
pc++;

printf("%f",*pf);
getch();
return 0;

本回答被提问者采纳

python格式化


1.百分号
格式如下:

%[(name)] [flags] [.precision] typecode

(name):可选,获取指定key的值
flags:可选,:width,占有宽度
.precision:可选,小数点后保留位数
typecode:必选
1)s,传入对象的__str__方法的返回值
2)c,整数
3)o,整数转八进制
4)d,整数转十进制
5)e,整数,浮点数转科学计数法
6)f,整数,浮点数转浮点数
7)F,整数,浮点数转浮点数
8)g,自动调整将整数,浮点数转浮点型或科学计数法
9)G,自动调整将整数,浮点数转浮点型或科学计数法
10)%,%%表示一个百分号

2.使用示例

result1 = "i am %s" % shijingjing07
result2 = "i am %s, score: %d" % (shijingjing07,100)
result3 = "i am %(name)s, score: %(age)d" % ({name:shijingjing07,age:100})
result4 = "%.2f" % 99.333
result5 = "%.2f%%" % 99.333
print(result1)
print(result2)
print(result3)
print(result4)
print(result5)

运行结果:
技术分享

3.format方式

result1 = I am {},age {},{}.format(shijingjing,2,hello)
result2 = I am {},age {},{}.format(*[shijingjing,2,hello])
result3 = I am {0},age {1},{0}.format(shijingjing,2)
result4 = I am {0},age {1},{0}.format(*[shijingjing,2])
result5 = I am {name},age {age},{name}.format(**{name:shijingjing,age:18})
result6 = I am {name},age {age},{name}.format(name=shijingjing,age=18)
result7 = I am {0[0]},age {0[1]},{0[2]}.format([1,2,3],[4,5,6])
result8 = I am {:s},age{:d}.format(shijingjing,2)
result8 = I am {name:s},age{age:d}.format(name=shijingjing,age=2)
result9 = numbers: {:b},{:o},{:d},{:x},{:X},{:%}.format(15,15,15,15,15,15.87623)
result10 = numbers: {0:b},{0:o},{0:d},{0:x},{0:X},{0:%}.format(15)
result11 = numbers: {num:b},{num:o},{num:d},{num:x},{num:X},{num:%}.format(num=15)
print(result1)
print(result2)
print(result3)
print(result4)
print(result5)
print(result6)
print(result7)
print(result8)
print(result9)
print(result10)
print(result11)

运行结果:
技术分享

以上是关于急求十六进制转浮点数C程序!!!的主要内容,如果未能解决你的问题,请参考以下文章

十六进制ascii码转浮点数

二进制/十六进制转浮点数的编程(互转类似)

c语言、浮点数怎么变成16进制

以IEEE754短浮点数格式表示十进制数:-3.125 要求写出过程,并最终用十六进制缩写形式表示

怎么将4字节16进制转化成浮点数

lua语言---浮点数转16进制