现在的位置: 首页 > 综合 > 正文

关于float转DWORD和DWORD转float

2013年03月24日 ⁄ 综合 ⁄ 共 439字 ⁄ 字号 评论关闭

c++代码如下,可以直接复制运行

	DWORD dw  = 0;
	float f1 = 0.25;

	cout<<"f1 = "<<f1<<endl;

	dw = *((DWORD*)&f1);
	cout<<"dw = *((DWORD*)&f1):  "<<dw<<endl;

	f1 = 0.0;
	cout<<"f1 = 0.0:  "<<f1<<endl;

	f1 = *((float*)&dw);
	cout<<"f1 = *((float*)&dw):  "<<f1<<endl;

运行结果如下

f1 = 0.25
dw = *((DWORD*)&f1):  1048576000
f1 = 0.0:  0
f1 = *((float*)&dw):  0.25

其实这就是利用了编译器转型的手段,这里float和DWORD都是4个字节长度,通过以上手段转型,不会丢失二进制的数据,所以也就不会丢失原始数据。

*((DWORD*)&f1),首先获取一个float指针,然后将其强制转换为DWORD类型的指针,最后解引用,获取的是一个DWORD类型的值,*((float*)&dw)则是同理

抱歉!评论已关闭.