- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我是初学者,有些东西对我来说意义不大。请能解释一下我哪里出错了。如果之前有人问过这个问题,我很抱歉。
这里小数点的存在意味着这些是使用浮点除法计算的。
System.out.println(1/3.0); // this prints: 0.3333333333333333
System.out.println(1.0/3); // this prints: 0.3333333333333333
System.out.println(1.0/3.0); // this prints: 0.3333333333333333
显然,下面是一个“截断整数除法”的例子。这对我来说似乎有点奇怪,但没关系。
System.out.println(1/3); // this prints: 0
是否可以这样说:“在下面的行中,(double) cast 被评估为第一个。它实际上是说:“将 1/3 视为 double - 不要使用截断整数除法。而是使用浮点除法。""
System.out.println((double)1/3); // this prints: 0.3333333333333333
下面,然而我们得到 0.0 - 这是怎么发生的?
System.out.println((double)(1/3)); // this prints: 0.0
好吧,也许额外的括号意味着 (1/3) 被评估为第一个。它使用截断整数除法进行评估,得到 0。然后应用 double 给我们 0.0 好的,这是有道理的
好吧,我们也许可以在这里提出一些通用规则:
规则 1:(双)表达式意味着首先应用(双)转换,然后计算表达式。
规则 2:(double) (expression) 表示计算表达式然后应用转换。太棒了!
因此在下一行中我们有:(int) 表达式,所以我想我们可以应用规则 1)。 (int) cast 被评估为第一个。它实际上是说:“将 1.0/3 视为一个 int - 不要使用像 double 那样多的内存。不要使用浮点除法,而是应用截断整数除法。”“所以我们有 0 对吗?不.
System.out.println((int)1/3.0); // this prints: 0.3333333333333333
好的,所以我们有 0.33333,因此 (int) 转换不会被评估为第一个。就好像它不存在一样。让我们提出第三条规则:
规则 3:(int) 表达式意味着完全忽略 (int) 转换,就像 (int) 甚至不存在一样评估表达式。
好的,将规则 3 应用于下面的行,我们有 (int) 但我们将忽略它。 1.0/3.0 用浮点除法求值,我们得到 0.3333333。成功!
System.out.println((int)1.0/3.0); // this prints: 0.3333333333333333
在下面的最后一行中,我们再次使用 (int) 但我们将忽略它。 (1.0/3) 使用浮点除法计算得到 0.3333333333 对吗?没有。
System.out.println((int)(1.0/3)); // this prints: 0
好吧,我现在很困惑。你能帮我解决这个问题吗?
最佳答案
Java 的语言解析规则基本上是根据其操作顺序 规则在您的代码中到处使用大量括号。了解 Java 认为括号在哪里将有助于您理解这种行为。当你说:
(double) 1 / 3.0
...这相当于说:
((double) 1) / 3.0
这意味着 1 被转换为 double ,而 3.0 自动成为 double ,因此您最终将进行浮点除法而不是整数除法。 (double) 1/3
也会发生同样的事情,因为除数是 double
,所以即使被除数是 int
,系统意识到你想做浮点除法。编译器不希望你失去精度,除非你特别要求,所以任何时候被除数或除数是double
,它会做double
部门。
另一方面:
(int) 1 / 3.0
...等同于说:
((int) 1) / 3.0
在这种情况下,您是在告诉编译器它已经知道的事情:除数 (1) 是一个 int
。然后你要求它除以 double
值 (3.0)。由于被除数是一个double
,它将执行double
除法。
如您所述,1/3
将产生零,因为这就是整数除法的工作原理并且两个数字都是整数。 1/(int)3.0
也会发生同样的情况,因为您要告诉编译器在除法之前将 3.0
转换为 int
发生(如 1/((int)3.0)
)。
要记住的最后一点是 (int) 0.33
也将转换为 0
,因为整数不能包含小数值。所以当你说 (int)(1.0/3)
时,你正在做 double
除法,但随后你将 double 转换为 int
之后,生成 0
。
关于java - 将转换应用于整数和浮点除法的结果 : what's going on here?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6949897/
我正在尝试编写一个简单的除法函数,但出现错误 PS C:\Users\john> Function Div($x, $y) { $x / $y } PS C:\Users\john> Div (1,
试图找出这个伪代码。以下假设...... 我只能使用无符号和有符号整数(或长整数)。 除法返回一个没有余数的实数。 MOD 返回一个实数。 不处理分数和小数。 INT I = 41828; INT C
如果我有以下表格并且我在关系代数中执行 R1/R2,结果会是一个具有 A 值 1 和 3 的表格吗?我有点困惑,因为我知道 3 将是一个结果,因为它包含 5 和 1,但结果 1 除了匹配的值之外还有
//Declare and intialize variables - programmer to provide initial values Scanner in = new Scanne
除法运算符在 scala BigDecimal 上有什么用? val d1 = BigDecimal(2) val d2 = BigDecimal(3) val div = d1 / d2 //thr
这个问题在这里已经有了答案: How can I divide properly using BigDecimal (2 个答案) 关闭 6 年前。 我在这里做错了什么?很确定这是正确的,我能够打印
好的 - 已经为此苦苦挣扎了一段时间。我刚刚开始学习 Python,所以非常新。 我有一个元组列表,需要按每个元组中值的比率进行排序。 输入: L = [(1,3), (1,7), (4,8)] 返回
我有一个奇怪的问题,我收到计算机生成的方程式(作为字符串),其中偶尔会出现零或一和零的乘法/除法。这些等式将以字符串形式呈现给用户。 我知道我可以通过实现一种解析器来删除等式中的这些冗余部分,但我很好
我有两个变量:count,这是我过滤的对象的数量,以及每页的常量值。我想将计数除以 per_page 并获得整数值,但无论我尝试什么 - 我都得到 0 或 0.0: >>> count = frien
我尝试在 Go 中获得 2.4/0.8 == 3 w:=float64(2.4) fmt.Println(math.Floor(w/0.8),math.Floor(2.4/0.8) ) 它给了我“2
程序清单: # val_caculate.py a = 10 # a是整数 print('10/3 = ',10/3) print('9/3 = ',9/3) pri
我是 java 新手,所以我需要你对我正在进行的项目的帮助!我定义了一些计数器,这些是我将使用的: int[] acceptCounters = {}; int[] acceptFailCounter
我正在除 2 个 BigInteger 值 N = 9440056782685472448790983739834832785827768777249804302814308027414135716
我的应用程序中有使用 array.reduce 将数字相乘的代码。它看起来像这样: // Private function to multiply field values together func
我目前创建了一个名为 Array Math 的类,它将乘法加载到 10x10 数组中,如代码下显示的图像所示,但是我想要做的是在乘法后将每个位置除以 2。换句话说,(行 * 列)/2 目前我只是将这些
我正在使用代表货币金额的 BigDecimal 值。我需要将此金额分成 6 个费率,前 5 个费率四舍五入为 5,其余的为第 6 个费率。 BigDecimal numberOfRates = new
这个问题必须使用递归来解决。 我尝试使用 “else” 之后的代码来使用 int temp 计算商,该 temp 计算可以除以多少次 (temp = dividend - divisor)。 int
我知道这一定是有史以来最简单的事情,但我是这里的初学者。为什么我运行时会出现语法错误 document.write(10 / 2 + ""); //Divide 10 by 5 to get 2
这应该是一个非常基本的东西,但不知何故我没有看到问题。 #include template inline void i2c(const int & ind, int & i, int &j) {
我正在做课本中的一些家庭作业,并且有一些关于某些算术运算的浮点舍入/精度的问题。 如果我像这样从 int 中转换 double : int x = random(); double dx = (dou
我是一名优秀的程序员,十分优秀!