java ieee_java – IEEE-754双(64位浮点)与长(64位整数)重访

该博客探讨了在Java中使用IEEE-754双精度浮点数(64位)与长整型(64位)进行转换时遇到的问题。作者发现某些情况下,数值在转换过程中不会发生溢出,尽管理论上它们超出了IEEE-754的表示范围。博客中提供了几个测试用例和判断数值是否溢出的方法,但结果并不如预期。文章讨论了可能的编译器优化和转换行为,并寻求解释。
摘要由CSDN通过智能技术生成

我正在重新审视一个问题(

How to test if numeric conversion will change value?),就我而言,完全解决了.问题是检测特定数值何时会溢出JavaScript的IEEE-754号码类型.上一个问题是使用C#,标记的答案工作完美.

现在我正在做完全相同的任务,但这次在Java中并不起作用. AFAIK,Java使用IEEE-754作为其双重数据类型.所以我应该能够来回传递来强制精确度的丢失,但是它能够进行全程的运行.受此限制,我开始在Java中深入挖掘,现在我真的很困惑.

在C#和Java中,long的最小值和最大值都相同:

long MIN_VALUE = -9223372036854775808L;

long MAX_VALUE = 9223372036854775807L;

AFAIK,由于为指数和符号保留的固定位,这些值在IEEE-754中的可表示数字之外.

// this fails in browsers that have stuck with the pure ECMAScript Number format

var str = Number(-9223372036854775808).toFixed();

if ("-9223372036854775808" !== str) { throw new Error("Overflow!"); }

这在Java中为(value = -9223372036854775808L)返回false:

boolean invalidIEEE754(long value) {

try {

return ((long)((double)value)) != value;

} catch (Exception ex

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值