当使用ruby的String#unpack
方法将二进制数据转换为浮动值时,我得到以下结果:
[0x7d, 0xe8, 0x80, 0xc5].map(&:chr).join.unpack('e')[0]
# => -4125.06103515625
这被认为是正确的结果。
使用C# BitConverter.ToSingle
方法可以得到以下结果:
var firstVal = BitConverter.ToSingle(new byte[] {0x7d, 0xe8, 0x80, 0xc5}, 0);
// firstVal: -4125.061
因此,这个值似乎被截断了。是否有方法从二进制表示中提取正确的值(如ruby
示例)?
发布于 2020-10-26 07:49:21
我记得,Ruby只有一种浮点数类型,那就是双精度浮点数。因此,您的红宝石表达式的值类型是双精度浮点数,在C#中的模拟值是"double“。因此,如果您想得到完全相同的数字,您可以这样做(但我不确定这是否有实际意义,请参见@xanatos注释):
var firstVal = (double) BitConverter.ToSingle(new byte[] {0x7d, 0xe8, 0x80, 0xc5}, 0);
// firstVal is -4125.06103515625
https://stackoverflow.com/questions/64532887
复制相似问题