我正在用 C# 开发一个可移植类库,我想将 double
位转换为 long
。此问题最直接的解决方案是使用 BitConverter.DoubleToInt64Bits
方法,但不幸的是,此方法在 .NET 类库的可移植库子集中不可用。
作为替代方案,我提出了以下“两次通过”位转换:
var result = BitConverter.ToInt64(BitConverter.GetBytes(x), 0);
我的测试表明此表达式始终产生与 DoubleToInt64Bits
相同的结果。但是,我的基准测试还表明,当在完整的 .NET Framework 应用程序中实现时,此替代公式大约比 DoubleToInt64Bits
慢 四 倍。
仅使用可移植库子集,是否可以实现比我上面的公式更快的 DoubleToInt64Bits
替换?
最佳答案
使用联合怎么样?
[StructLayout(LayoutKind.Explicit)]
public struct DoubleLongUnion
{
[FieldOffset(0)]
public double Double;
[FieldOffset(0)]
public long Long;
}
public static long DoubleToInt64Bits(double value)
{
var union = new DoubleLongUnion {Double = value};
return union.Long;
}
关于c# - .NET Portable 库缺少 BitConverter.DoubleToInt64Bits,替换非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10517101/