- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我用这些语句来测试
float f=4.35f;
int i=(int)(f*100);
System.out.println(i);
double d=4.35;
i=(int)(d*100);
System.out.println(i);
结果是
435
434
我曾经认为 float 和 double 之间的唯一区别只是精度。它们在计算中应该相同。但是我把4.35转成二进制再转回十进制,发现其实是4.3499999...因此,如果我将它乘以 100 然后进行转换,我认为答案应该是 434,同时具有 float 和 double。为什么第一个是435?
最佳答案
Java 中的 float 使用二进制表示。许多具有十进制短精确表示的数字,例如 4.35
,在任何精度下都没有二进制的精确表示(例如 float
、double
或另一个)。
当您在 Java 程序中编写 4.35
时,它被解释为表示最接近 435/100 的 double
。当您编写 4.35f
时,它被解释为表示最接近 435/100 的 float
。
碰巧 4.35
和 4.35f
都略低于 435/100:在Java中,4.35
代表4.3499999999999996447286321199499070644378662109375,4.35f
代表4.349999904632568359375。在第一个近似值中,这两种类型中最接近的可表示值都低于目标 435/100 的可能性很小(尽管在更深入地观察它时,它没有任何随机性)。
另一方面,数字 435
可以完全表示为 float
和 double
。
当将 4.35f
或 4.35
乘以 100 时(也可以精确表示为 float
和 double
), 出现以下两种可能性之一:
相乘的数学结果比任何其他 float 更接近 435。然后选择 435
作为操作的结果。您必须记住,Java 并不知道它正在乘以一个本应为 4.35 的数字。据它所知,你是故意选择了一个低于 4.35 的数字。也许您真的希望操作数为 4.349999904632568359375。这是乘法过程中二次近似的结果,最终结果是 435。无论如何,将 float 435
转换为 int
会产生 int 435
。这就是 float
的情况。
乘法的数学结果最接近 435 以下的 float 。在本例中,选择该 float 作为浮点乘法的结果。将此结果转换为 int
会生成 434
,因为从 float 到整数的转换是通过截断 进行的。这就是 double
的情况。 Multiplying 4.3499999999999996447286321199499070644378662109375
by 100 produces a mathematical result that is close to the double
immediately below 435.0
(this double
is 434.99999999999994315658113919198513031005859375 ),因此这个 double
被用作浮点乘法的结果。
关于java - 在 java 中将 float 和 double 转换为 int 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24099337/
这个问题在这里已经有了答案: How to initialize var? (11 个答案) 关闭 8 年前。 我想给一个变量赋初值 null,并在下一个 if-else block 中赋值,但是编
我正在使用 TypeScript 3.8 编写 JS 和 TS 混合的代码。我写了以下行: export * as Easing from './easing'; 应该是 fair game在 Typ
我需要将 R 代码中的“/”更改为“\”。我有这样的事情: tmp <- paste(getwd(),"tmp.xls",sep="/") 所以我的 tmp是 c:/Study/tmp.xls 我希望
我有个问题。例如我有这个: id truth count 1 1 1 2 1 2 3 0 0 4 1 1 5 1 2 6 1
我正在尝试使用“IN”和“=”来查找一些 bean。我目前正在使用此代码: $ids = array(1,2,3,4); $user = 1; $things = R::find( 'thing'
是否可以在 Xcode 中部署到其他人的手机上?我没有 iPhone,但我想测试我在 friend 手机上制作的应用程序。在我支付 99 美元之前,我想确保这不会造成麻烦。 谢谢。 最佳答案 不会有任
我试图得到一个非常大的数字(超过 unsigned long long int )。所以我把它作为一个字符串,然后一个数字一个数字地转换成整数并使用它。 #include #include int
我在 Rust 中有 C 语言库的绑定(bind),但它们并不完整。 在 C 代码中,我定义了一个简化的宏,如下所示: #define MY_MACROS1(PTR) (((my_struct1
我正在努力解决这个问题。 http://jsfiddle.net/yhcqfy44/ 动画应该自动相对于 滚动到顶部每次出现滚动条时的高度。 我已经写了这个,但没有运气: var hheight =
我正在处理一个将数字作为字符串返回的 JSON API。例如 "12" ,但是,该字段值也可以是非数字的,例如:"-" . 我已将 JSON 数据解析为映射,我想将此字段提取为 elixir 中的整数
我正在尝试编写一个类,将.wav文件转换为.aiff文件作为项目的一部分。 我遇到了几个库Alvas.Audio(http://alvas.net/alvas.audio,overview.aspx)
我想在 Lucene 中将像“New York”这样的“复合词”索引为单个术语,而不是像“new”、“york”那样。这样,如果有人搜索“new place”,则包含“new york”的文档将不会匹
我希望这个解释能让我更好地了解使用宏的优点。 最佳答案 在函数中,所有参数在调用之前都会被评估。 这意味着 or 作为函数不能是惰性的,而宏可以将 or 重写为 if 语句,该语句仅在以下情况下计算分
我有一些看起来像这样的 XML foo ]]> (注意 > 登录 "> foo")和 XSLT 样式表 当我运行xsltproc stylesheet.xs
当我尝试将 Any 转换为 List 时,如下面的示例所示,我得到“Unchecked cast: Any!”到列表'警告。有没有解决此类问题的方法? val x: List = objectOfTy
我正在使用 Python 开发一个简单的爬虫。目的是创建一个 sitemap.xml。(你可以在这里找到真正的 alpha 版本:http://code.google.com/p/sitemappy/
我想知道在 VBScript 中是否可以在多行中中断 If 语句。喜欢: If (UCase(Trim(objSheet.Cells(i, a).Value)) = "YES") Or _ (UCas
for (String item : someList) { System.out.println(item); } 使用“do while”是否等效? 谢谢。 最佳答案 如果列表为空,f
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Split string with delimiters in C 在 C 中将“,”分隔的列表拆分为数组的最佳方法
我有一个如下所示的字符数组: [0, 10, 20, 30, 670] 如何将此字符串转换为整数数组? 这是我的数组 int i=0; size_t dim = 1; char* array = (c
我是一名优秀的程序员,十分优秀!