当前位置: 首页 > 编程笔记 >

在C#中将指定的双精度浮点数转换为64位带符号整数

茹正初
2023-03-14
本文向大家介绍在C#中将指定的双精度浮点数转换为64位带符号整数,包括了在C#中将指定的双精度浮点数转换为64位带符号整数的使用技巧和注意事项,需要的朋友参考一下

要将指定的双精度浮点数转换为64位带符号整数,代码如下-

示例

using System;
public class Demo {
   public static void Main() {
      double d = 5.646587687;
      Console.Write("Value = "+d);
      long res = BitConverter.DoubleToInt64Bits(d);
      Console.Write("\n64-bit signed integer = "+res);
   }
}

输出结果

这将产生以下输出-

Value = 5.646587687
64-bit signed integer = 4618043510978159912

示例

让我们看另一个例子-

using System;
public class Demo {
   public static void Main() {
      double d = 0.001;
      Console.Write("Value = "+d);
      long res = BitConverter.DoubleToInt64Bits(d);
      Console.Write("\n64-bit signed integer = "+res);
   }
}

输出结果

这将产生以下输出-

Value = 0.001
64-bit signed integer = 4562254508917369340
 类似资料:
  • 本文向大家介绍在C#中将64位带符号整数重新解释为双精度浮点数,包括了在C#中将64位带符号整数重新解释为双精度浮点数的使用技巧和注意事项,需要的朋友参考一下 要将指定的64位带符号整数重新解释为双精度浮点数,代码如下- 示例 输出结果 这将产生以下输出- 示例 让我们看另一个例子- 输出结果 这将产生以下输出-

  • 在C++中如何将浮点数转换为字符串,同时指定精度&小数位数? 例如:

  • 问题内容: 我正在尝试将以下十六进制字符串转换为“ 41630D54FFF68872”到9988776.0(float-64)。 使用单精度float-32,我可以这样做: 但这会引发:java.lang.NumberFormatException:使用上面的64位十六进制时,Infinite或NaN。 如何将十六进制转换为使用64位IEEE-754编码的双精度浮点数? 谢谢 问题答案: 您需要双

  • 我想用一个小数点和一个小数位的格式将任何双精度四舍五入为双精度,这样29575.347434将是2.3。 我试着用decimalFormat做这个,但当我试着我只得到了一个29575.3格式的字符串,带有一个,我不知道如何在保留值为双精度的同时去掉所有小数点。

  • 我试图得到一个double(由两个int的分数得到)作为我下面函数的返回值。 但结果总是错的,我得到的价值如: 预期结果应介于和 我的代码有什么问题! 谢谢

  • 问题内容: 我有一个浮点数组,我想将其转换为Java中的双精度数组。我知道迭代数组并创建一个新数组的明显方法。我希望Java在希望与double []一起工作的地方能够平稳地消化float [] …,但不能与此一起工作。进行这种转换的优雅,有效的方法是什么? 问题答案: 基本上 , 必须进行每个值的转换。两种数组类型之间没有隐式转换,因为在JITting之后用于处理它们的代码将有所不同- 它们具有