我正在用C#开发一个可移植的类库,我希望将double转换为long.这个问题最直接的解决方案是使用BitConverter.DoubletoInt64Bits方法,但不幸的是,这个方法在.NET类库的Portable Library子集中不可用.
作为替代方案,我提出了以下“双通”位转换:
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; }
原文地址:https://www.jb51.cc/csharp/91807.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。