草庐IT

BINARY_DOUBLE

全部标签

java - 为什么 long 和 double 在 Java 类的常量池中占用两个条目?

JavaVirtualMachineSpecification声明8字节(例如long和double)常量占用constant_pool表中的两个条目,不像其他常量只占用每一个条目。该规范还提到这是一个糟糕的选择,但没有解释原因。这个设计决定背后的最初原因是什么?当时的好处是什么? 最佳答案 明确的答案需要与参与Java早期开发的人员交谈。但是,我认为很明显,字节码格式最初设计时考虑的是朴素解释器的性能。考虑如何编写一个非常简单的Java字节码解释器。没有JIT,没有优化等。您只需执行每条指令即可。假设常量池在加载时已被解码为32位

java - 通缉 : Recurrence Formula of In-Order binary tree output method

我在寻找这个java方法的递推公式时遇到了麻烦voidprintInorder(Nodev){if(v!=null){printInorder(v.getLeft());System.out.println(v.getData());printInorder(v.getRight());}}一些标准:它是一棵完全二叉树(每个内结都有2个child,每片叶子的深度相同)这棵树有n个节点,复杂度为O(n)我必须找到与n结的树的深度h相关的递归公式,作为额外的奖励,我需要外推显式从中得出O(n)的公式。现在,这就是我得到的:d=depthofthetreec=constantruntimef

java - 对于 double f,float g,如何找到最大的 int i,使得 i*g <= f

更新:谢谢凯文,我的意思是标题中的这是正确的吗?在这个问题上花费了令人尴尬的时间之后,这是我所管理的最好的:publicintcandidate_answer(doublef,floatg){inttest=(int)Math.floor(f/g);if((test+1)*g背景:该应用程序是一个简单的游戏,我从以前的程序员那里接管了它的所有权。奇怪的是,他选择在成员变量和参数变量中随意混合float和double,因此有很多不必要的隐式和显式转换。玩家坐标为doublex,y(假设玩家是一个点)。有一个floatTILE_SIZE,世界是一些行数和列数的图block,加上一些通用的越

java - 为什么不能将 Byte 对象/字节值转换为 Double 对象?从 Byte 到 Double 的转换会影响精度吗?

publicclassPrimitive{publicstaticvoidmain(String[]args){bytex=5;Doubley=(Double)x;//Error:CannotcastfrombytetoDouble.Byten=7;Doublem=(Double)n;//Error:cannotcastfromBytetoDouble.doublec=n;//workingright..."doubleisprimitiveandByteisobject".}}阻止将Byte转换为Double有什么意义?..如果我没记错的话,出于精确原因我知道DoubletoByte

Java - 通过转换为 double 在 long 中查找前导零

在找到方法之前Long.numberOfLeadingZeros(longi),我将多头投向double并使用Math.getExponent(doubled).想法是找到long的double表示,使用指数获得最高设置位,然后从64中减去它以获得前导零的数量。这主要是有效的,但偶尔会偏离1。使用以下for循环来突出问题:for(inti=0;i>>i;doublemin=Long.MIN_VALUE>>>i;doubleneg=-1L>>>i;System.out.format("Max:%-5dMin:%-5d-1:%-5d%n",Math.getExponent(dmax),Ma

Java 8 - 检查 Double 是否在范围内?

我知道对于整数,Java8具有IntStream,它允许您生成范围并检查它们,例如IntStreamrange=IntStream.rangeClosed(5,10);range.anyMatch(x->x==4);我的问题是我有Double范围,定义为:Light[0,3.0)Moderate[3.0,6.0)Vigorous>=6.0根据这些范围检查的变量是一个doubleval。我只是想知道Java8是否对此有任何方便的解决方案。出于各种原因,我不想使用复杂的if/else树。 最佳答案 如pkpnd在其comment中所述,

java - 为什么我得到 org.hibernate.HibernateException : IOException occurred reading a binary value

我在我的日志中发现了这个我以前从未见过的异常​​,我使用的是Hibernate4.1.7这是否表明我的数据库已损坏,或者这是Hibernate中的错误。我在http://lists.jboss.org/pipermail/hibernate-issues/2010-November/026487.html找到了对此错误的引用但这指的是更早版本的hibernate并且已针对Hibernate4.0修复org.hiorg.hibernate.HibernateException:IOExceptionoccurredreadingabinaryvalueatorg.hibernate.ty

Java 并行流 : there's a way to navigate a binary tree?

我正在努力寻找一种适当的方法来从这个流中获得加速:StreamSupport.stream(newBinaryTreeSpliterator(root),true).parallel().map(node->processor.onerousFunction(node.getValue())).mapToInt(i->i.intValue()).sum()onerousFunction()只是一个使线程工作一段时间并返回节点的int值的函数。无论我使用多少cpu,执行时间始终保持不变。我认为问题出在我写的Spliterator中:publicclassBinaryTreeSpliter

java - Double != null 导致 NullPointerException

我有以下代码片段让我感到困扰,其中currentRate和secondCurrentRate是正确定义的Double对象:(currentRate!=null&&secondCurrentRate!=null)?currentRate*secondCurrentRate:null;这应该检查每个Double是否为空,并相应地分配值null。但是,如果secondCurrentRate为null,则会导致NullPointerException。我已将代码段更改为:(currentRate==null|secondCurrentRate==null)?null:currentRate*s

java - 将 double 转换为另一种数字类型

有些事情让我感到困惑,我没有找到太多关于VM规范的信息。这有点晦涩,如果有人能向我解释,那就太好了。这几行代码......doublemyTest=Double.MAX_VALUE;System.out.println("1.float:"+(float)myTest);System.out.println("2.int:"+(int)myTest);System.out.println("3.short:"+(short)myTest);System.out.println("4.byte:"+(byte)myTest);.....产生这个输出:float:无限整数:21474836