Double-precision_floating-point_f
全部标签 我一直对这个有点好奇。Math.random()给出[0.0,1.0)范围内的值。那么它能给出的最大值(value)是多少呢?换句话说,小于1.0的最接近1.0的double值是多少? 最佳答案 Java使用64位IEEE-754表示,因此理论上小于1的最接近数字是十六进制表示形式的3FEFFFFFFFFFFFFFF,符号为0,指数为-1,52位有效数为1.9999999999999997。这大约等于0.9999999999999998。引用文献:IEEE-754Calculator.
我正在制作一个加密任何类型文件的小型Java程序。我这样做的方式如下:我打开输入文件,在与该文件大小相同的字节数组中读取它,然后进行编码,然后将整个数组写入名为输出的.dat文件。数据。为了索引字节数组,我使用了一个int类型的变量。代码:for(inti:arr){if(i>0){arr[i]=arr[i-1]^arr[i];}}'arr'是一个与输入文件大小相同的字节数组。我得到的错误:CodingEvent.java:42:error:possiblelossofprecisionarr[i]=arr[i-1]^arr[i];(箭头指向^运算符)必需:字节发现:整数怎么了?你能帮
考虑以下语句:byteby=5;//工作正常字面量'5'是int类型并且足够小以适合byte类型的变量。编译器在这里进行隐式类型转换(从int到byte)。现在考虑以下场景:floatfl=5.5;//compilationerror文字'5.5'是double类型,也足够小以适合变量类型float。为什么我们需要像这样显式地类型转换:floatfl=(float)5.5;//worksfine为什么编译器不为我们进行浮点类型转换? 最佳答案 在整数版本中,编译器知道所有数字5中的数据可以存储在一个字节中。没有信息丢失。对于浮点值,
这个问题在这里已经有了答案:Whatisthedifferencebetweenthefloatandintegerdatatypewhenthesizeisthesame?(3个答案)关闭3年前。看看Java(但在其他语言中可能相似或相同),long和double都使用8个字节来存储一个值。一个long用8个字节存储从-9,223,372,036,854,775,808到9,223,372,036,854,775,807的长整数double使用8个字节来存储从-1.7E308到1.7E308的doublefloat,最多16位有效数字。我的问题是,如果两者都使用相同的字节数(8个字节
以下是否存在精度差异(假设a和b的值可以在不损失精度的情况下用float表示)。有花车:floata;floatb;doubleresult=1+a*b;double:doublea;doubleb;doubleresult=1+a*b; 最佳答案 简单的例子:floata=16777217;//Largestintexactlyrepresentableinafloat.floatb=16777217;System.out.println((double)(1+a*b));doublec=16777217;doubled=1677
考虑以下代码片段floatnum=281.583f;intamount=(int)Math.round(num*100f);floatrounded=amount/100.0f;doubledblPrecision=rounded;doubledblPrecision2=num;System.out.println("num:"+num+"amount:"+amount+"rounded:"+rounded+"dbl:"+dblPrecision+"dbl2:"+dblPrecision2);我得到的输出是num:281.583amount:28158rounded:281.58dbl
下面的返回是做什么的?我如何使用该值:privateMaptheLabels=newHashMap();publicDouble[]getTheLabels(){returntheLabels.keySet().toArray(newDouble[0]);}这是正确的吗?Double[]aD=theClassInQuestion.getTheLabels();提前致谢。胡志明 最佳答案 这是正确的,但是,除非theLabels为空,否则强制重新分配数组。这是一个替代方案:publicDouble[]getTheLabels(){re
Java中double值的乘法运算符保证的精度是多少?例如,2.2*100是220.00000000000003,但220是双数。220.00000000000003是220之后的下一个双数。 最佳答案 乘法工作正常,但2.2不能精确表示为double。最接近的double是:2.199999999999999733(0x4001999999999999)2.200000000000000177(0x400199999999999a)某些软件会将后一个值打印为2.2,但这并不意味着它是准确的。这只是意味着它被视为“足够接近”。
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion我试图断言我的替身是NaN。这是一个代码片段:privateDoublecalculateIt(Stringinput){...}assertEquals(Double.NaN,calculateIt("inputtext"));代码无法编译,Double.NaN被定义为原语publicstaticfinaldoubleNaN=0.0d/0.0;为了使断言有效,我用Double对象包装了N
我正在练习一些简单的2D游戏编程,并提出了一个理论,即在动画期间(图像位置的实际变化最好用float计算)。我有一种感觉,如果你用整数移动图像,动画就不会那么流畅。在Java中,您似乎无法使用float绘制图像来为图像指定位置。但是显然,当您最初声明您的x和y时,您可以将它们声明为Double或Float,并且当涉及到实际绘制图像时,您必须转换他们到整数。就像我发现HERE:/***Drawthisentitytothegraphicscontextprovided**@paramgThegraphicscontextonwhichtodraw*/publicvoiddraw(Grap