当前位置: 首页 > 知识库问答 >
问题:

用括号中的技巧将除法值转换为双精度

孟德曜
2023-03-14

下面有括号和没有括号的代码产生不同的输出。为什么?

System.out.println((double) 3/6);    // output 0.5

System.out.println((double) (3/6));  // output 0.0

共有2个答案

翟英达
2023-03-14

在第一个例子中,在除以int之前,您将3转换为双精度。根据Java类型转换规则,输出是双(在本例中为0.5)。

在第二个例子中,你把一个整数除以一个整数。因为你要除以的数字比你要除以的数字小,所以答案是零。然后你只需将int 0转换为double 0。

陈增
2023-03-14

因为在第一个例子中,您实际上正在执行((双)3)/6,因此结果也是双的。

在第二种情况下,执行整数除法,然后对结果进行强制转换<代码>3/6=0,以及(双)0=0.0

 类似资料:
  • 我是Matlab新手,所以这应该是一个简单的问题。我有一个带有几个特定像素的图像,我需要从中获取红色RGB分量,求和,并将结果存储到一个变量中。默认情况下,这些值的类型为uint8,因此总和不能超过255。我尝试使用double()的每个组合将R值转换为double,但似乎没有任何效果。下面是从终端复制的实际情况:(所有像素的R值都在200以上) 我做错了什么?我不能将这些值转换为双精度值吗?

  • 我试图得到一个double(由两个int的分数得到)作为我下面函数的返回值。 但结果总是错的,我得到的价值如: 预期结果应介于和 我的代码有什么问题! 谢谢

  • 对于实现精确 IEEE 754 算术的 C99 编译器,是否存在型的 、的值,使得 ? 编辑:所谓“实现精确的IEEE754算法”,我指的是一个正确地将FLT_EVAL_METHOD定义为0的编译器。 提供符合IEEE 754标准的浮点数的C编译器只能将单精度除法替换为常数,如果所述逆本身可以完全表示为。 实际上,这种情况只发生在2的幂上。因此,程序员Alex可能确信< code>f / 2.0f

  • 我想用一个小数点和一个小数位的格式将任何双精度四舍五入为双精度,这样29575.347434将是2.3。 我试着用decimalFormat做这个,但当我试着我只得到了一个29575.3格式的字符串,带有一个,我不知道如何在保留值为双精度的同时去掉所有小数点。

  • 我还是一名学生,刚开始学习java编程语言,我只是想问一下如何将函数main中的参数从字符串转换为double,就像将字符串转换为整数一样。pasreInt(arg)

  • 问题内容: 我有一个双,其值是10,000,000.00(千万)。我必须将其转换为。当使用该方法时,我会得到 “ 1.0E7”,它遵循规范是正确的。不幸的是,我需要“ 10,000,000.00”(或等价的语言,具体取决于语言环境)。 如何做到这一点? 问题答案: 尝试之一 NumberFormat http://java.sun.com/javase/6/docs/api/java/text/N