在Java中将double转换为无符号整数

问题描述

我正在尝试在 Java 中将 double 转换为 unsigned int。

unsigned int 我的意思是从 0 到 4294967295 的范围。
我使用 int 作为载体 - 它可以转换为带有 Integer.toUnsignedString 的字符串。

我不在乎得到什么结果

  • double 是 NaN
  • double 是 Inf-Inf
  • 双精度超出范围:< 0> 4294967295

只要我得到任何结果。

简单的演员表不起作用:

(int) 4294967295d == 2147483647
(int) 2147483648d == 2147483647

所以有问题的范围是 2147483648d - 4294967295d

是否有一种快速方法可以正确覆盖该范围?

tl;dr:在 C 中我会使用 (unsigned int) dblValue - 我会在 Java 中使用什么?

解决方法

4294967295f

那不是一回事。那个浮动不存在。它变得圆润。不要使用浮点数,它们几乎没有意义。它可以作为双人使用。

是否有一种快速的方法可以正确覆盖该范围?

一旦你意识到你的问题没有意义并转向双打,是的。转换为 long,转换为 int:

double d = 4294967295.0;
int i = (int) (long) d;
System.out.println(i);
System.out.println(Integer.toUnsignedString(i));
> -1
> 4294967295