草庐IT

floating-point-comparison

全部标签

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 - 带 float 的无限循环

这个问题在这里已经有了答案:doubleorfloatdatatypedoesn'taddupproperlyinaloop?(5个答案)关闭5年前。我目前正在学习javafloat。我知道,float有一定数量的重要数字。我也知道,float在Java中表示为-1或1*num*10^x。其中num是数字,10^x是小数点。但是在这里我们没有数字的一小部分。这里怎么可能出现无限循环?死循环代码:floatf=123456789;while(f-->0){System.out.println(f);}

java - 加减精确值以 float

问题:float的总数是有限的,大约有2^32个。使用float,您可以使用java.lang.Math.nextAfter直接转到下一个或上一个。我称之为一次飞跃。我的主要问题(由子问题组成)是,如何使用leaps在float车上导航?首先,我怎样才能一次将一个float移动到另一个点?publicstaticfloatmoveFloat(floatvalue,intleaps){for(inti=0;i这种方式在理论上应该可行,但实际上并未优化。如何在一次添加中完成?我还需要知道2个float之间有多少跳跃。这是这个的示例实现:publicstaticintgetLeaps(flo

java - float x[] 与 float[] x 有什么区别?

这个问题在这里已经有了答案:Differencebetweenint[]arrayandintarray[](26个答案)关闭8年前。我在看一个视频,他们展示了他们正在建立一个像这样的float组:privatefinalfloatx[];我一直这样做:privatefinalfloat[]x;我对两者都进行了测试,但均未产生错误。有区别还是这只是偏好?

java - 无法复制 : "Comparison method violates its general contract!"

我收到以下错误:“比较方法违反了它的一般契约(Contract)!”使用以下比较器时,但是我无法使用jUnit复制异常。我想知道是什么导致了这个问题以及如何复制它。有其他人遇到同样问题但不知道如何复制的例子。publicclassDtoComparatorimplementsComparator{@Overridepublicintcompare(Dtor1,Dtor2){intvalue=0;value=r1.getOrder()-r2.getOrder();if(value==0&&!isValueNull(r1.getDate(),r2.getDate()))value=r1.g

java - 我应该使用 Point.x 还是 Point.getX()?

我有一个点。我正在尝试将x作为int。如果我使用Point.x,我将得到x作为int。但我的印象是我应该尽可能使用setter/getter(Whyusegettersandsetters?)。Point.getX()的问题是它返回一个double而不是一个整数。哪个更好,还是只是偏好?a还是b?Pointpoint=newPoint(5,5);inta=point.x;intb=(int)point.getX();我已阅读JavaPoint,differencebetweengetX()andpoint.x,但它并没有真正回答我的问题。或者至少我不明白答案。

Java 允许将 int 隐式转换为 float。为什么?

在Java中,我们可以将int隐式转换为float,这可能会导致精度损失,如下面的示例代码所示。publicclassTest{publicstaticvoidmain(String[]args){intintVal=2147483647;System.out.println("integervalueis"+intVal);doubledoubleVal=intVal;System.out.println("doublevalueis"+doubleVal);floatfloatVal=intVal;System.out.println("floatvalueis"+floatVal

Java "Jackson"JsonMappingException : Can not deserialize instance of float out of FIELD_NAME token

与这个类:publicclassProductsimplementsSerializable{privateBigDecimalproductId;privatefloatpriority;publicfloatgetPriority(){returnpriority;}publicvoidsetPriority(floatpriority){this.priority=priority;}}在对此类JSON数据进行反序列化时:{"productId":47552,"priority":78}出现这个错误:org.codehaus.jackson.map.JsonMappingExce

c# - 可以精确表示为 float / double 的整数范围

这个问题在这里已经有了答案:What'sthefirstdoublethatdeviatesfromitscorrespondinglongbydelta?(4个答案)WhichisthefirstintegerthatanIEEE754floatisincapableofrepresentingexactly?(2个答案)关闭9年前。可以表示为double(resp.float)的(连续)整数的确切范围是多少?我问的原因是因为我对questionssuchasthisone很好奇。何时会发生准确性损失。也就是最小正整数m是什么使得m+1不能精确地表示为double(resp.floa

java.lang.IllegalArgumentException : Comparison method violates its general contract! java.util.Date

java.lang.IllegalArgumentException:Comparisonmethodviolatesitsgeneralcontract!atjava.util.TimSort.mergeLo(TimSort.java:747)atjava.util.TimSort.mergeAt(TimSort.java:483)atjava.util.TimSort.mergeCollapse(TimSort.java:410)atjava.util.TimSort.sort(TimSort.java:214)atjava.util.TimSort.sort(TimSort.ja