四字节16进制数转化成浮点数的原理是什么?
四字节16进制数可转换为四个⼆进制字节(Bytes),从⽽使⽤Api函数来处理成单精度浮点数。
以下⽤VB代码处理。
VB有专门的API函数CopyMemory能处理2-10进制浮点数转换和10-2进制浮点数转换。
下列代码演⽰了10进制Single(单精度浮点型转为16进制字符显⽰的浮点数和其相反运算:
Option Explicit
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
Private Sub BinToSin_Click()
Dim sinStr As String
Dim sinSj As Single
Dim Buffer(3) As Byte
Dim i As Integer
sinStr = Text2
For i = 1 To Len(Text2) Step 2
Buffer((7 - i) / 2) = Val("&H" & Mid(sinStr, i, 2))
Next
CopyMemory ByVal VarPtr(sinSj), ByVal VarPtr(Buffer(0)), 4
Text3 = sinSj
End Sub
Private Sub SinToBin_Click()
Dim i As Integer
Dim hexData As String
Dim a As Single
Dim Buffer(3) As Byte
a = Val(Text1)
CopyMemory Buffer(0), a, 4
For i = 0 To 3
If Len(Hex(Buffer(i))) = 1 Then
hexData = "0" & Hex(Buffer(i)) + hexData
Else
hexData = Hex(Buffer(i)) + hexData
End If
Next
Text2 = hexData
End Sub
需要注意的事项是这四字节的⾼低字节排序,不能搞错。
VB的Single 数据类型
Single(单精度浮点型)变量存储为 IEEE 32 位(4 个字节)浮点数值的形式,它的范围在负数的时候是从 -3.402823E38 到 -1.401298E-45,⽽在正数的时候是从 1.401298E-45 到 3.402823E38。Single 的类型声明字符为感叹号 (!)。
在内存以32位⼆进制形式存在:
XXXXXXXX XXXXXXXX XXXXXXXX XXXXXXXX
第1位为符号位
第2-9位为阶码位
第10-32位为2进制⼩数尾值
即F2 ^ n * 1. XXXXXXX XXXXXXXX XXXXXXXX
其中
F为正号或负号(⾸为为0正数,⾸位为1负数
n为2-9位组成的BYTE数据值
XXXXXXX XXXXXXXX XXXXXXXX为尾数
////////////////////////////////////////////////////////////////////////////////
1、4字节指的是有4个内存单元,每个单元各放着⼀个0~255的整数,拼凑起来形成⼀个32个⼆进制位的数⼉;
2、根据不同的视⾓来看待或理解这个数⼉,可以得出很多不同的答案;
3、针对你的问题,其实是“将视⾓切换为单精度浮点数”,单精度浮点数在内存单元中如何表⽰,是个挺复杂的事⼉,具体是国际电⽓标准754规定的,如果你能看懂,绝对可以品味到其中的精彩,这个才是最核⼼的“原理”;
4、从你的描述上看,似乎也并不是想了解到最底层的透彻,仅仅是了解这段程序如何能⼯作,如果是这样的话,答案是:强制类型转换。(float*)&c的意思是带上⼀副“单精度浮点数”的眼镜,去看c数组中的内容,前⾯再加⼀个*,意思是“看好了,拿出来”。
///////////////////////////////////////////////////////////////////////////////////////
c++?c局部变量只能放在函数开头
float pfValue=*(float*)&c;
浮点数的基数什么意思
&cByte的地址当作(float*)型指针取内容