将双精度值转换为其字节表示的简单方法?我尝试使用如下指针:
var
double_v:double;
address:^double;
....
double_v:=100;
address:=@double_v;
但我的每一个概念:如何从地址中读取这8个字节,以“AV”结尾。
使用变体记录
Type
TDoubleAndBytes = Record
case boolean of
false : (dabDouble : Double);
true : (dabBytes : Array [0..7] Of Byte);
end;
将双精度值分配给 dabDouble 并通过 dabBytes 读取字节
var
myVar : TDoubleAndBytes;
i : integer;
begin
myVar.dabDouble := 100;
for i:=0 to 7 do write(myVar.dabBytes[i]);
在 XE3 中有用于简单类型的记录助手,TDoubleHelper
.
这有效:
var
d : Double;
i : Integer;
begin
d := 100.0;
for i := 0 to 7 do
WriteLn(d.Bytes[i]);
end;
在 XE2 中有一个声明TDoubleRec
,这是一个高级记录。
例子:
var
dRec : TDoubleRec;
i : Integer;
begin
dRec := 100.0;
for i := 0 to 7 do
WriteLn(dRec.Bytes[i]);
end;
访问双精度字节的另一个常见选项是使用 a typecast
:
type
TDoubleAsByteArr = array[0..7] of byte;
var
d : Double;
i : Integer;
begin
d := 100.0;
for i := 0 to 7 do
WriteLn(TDoubleAsByteArr(d)[i]);
end;
使用“绝对”的两个例子......
用作函数
function GetDoubleByte(MyDouble: Double; Index: Byte): Byte;
var
Bytes: array[0..7] of Byte absolute MyDouble;
begin
Result := Bytes[Index];
end;
procedure TForm1.Button1Click(Sender: TObject);
var
MyDouble:Double;
DoubleBytes:Array[0..7] of Byte absolute MyDouble; // direct local use
begin
MyDouble := 17.123;
ShowMessage(IntToStr(DoubleBytes[0])); // local usage
ShowMessage(IntToStr(GetDoubleByte(MyDouble,0))); // via function call
end;