java做除法运算,为什么除不开时也会得到整数呢

除法运算/的功能是有区别的。如果相除的两个数都是整数,那么结果也是整数,这叫做取整除法。比如,3/2,结果是1。如果其中有一个是浮点数,那么就是浮点除法,结果是浮点数,比如,3.0/2,结果是1.5.
java做除法运算,为什么除不开时也会得到整数呢
因为你运算时用的是int
int计算普通情况得到的也是int

想要小数用浮点型2008-10-04
这个是默认定义的值的类型是int类型导致的。
如:5/2;此时结果为:2,因为5和2都是默认的int类型。
如果不想得到整形,那么必须定义分子和分母都是double类型才可以。
double a = 2;
double b = 5;
System.out.println(b/a);
结果就是:2.5.2015-11-05
除法运算/的功能是有区别的。如果相除的两个数都是整数,那么结果也是整数,这叫做取整除法。比如,3/2,结果是1。如果其中有一个是浮点数,那么就是浮点除法,结果是浮点数,比如,3.0/2,结果是1.5.2008-10-04
如果你想要带小数的结果那么在声明的时候就要把变量声明成浮点型
float
=
0.0f
double
=
0.0
补充
因为你声明的5和2都是int型的变量,所以计算出来的结果也是int型的,int型是整型变量,没有小数部分,所以要把它们声明成浮点数(即小数),例如float=5.0f;float
=
2.0f;后边的f表示2.0是float型的单精度浮点数,如果不带f则是默认的double型双精度浮点数。两个float型的数字相除,这样计算的结果也使float型的,所以就会有小数部分出现了2020-04-29
/**
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
* 定精度,以后的数字四舍五入。
* @param v1 被除数
* @param v2 除数
* @param scale 表示表示需要精确到小数点以后几位。
* @return 两个参数的商
*/
public static double div(double v1, double v2, int scale) {
if (scale < 0) {
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}2008-10-04
/**
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
* 定精度,以后的数字四舍五入。
* @param v1 被除数
* @param v2 除数
* @param scale 表示表示需要精确到小数点以后几位。
* @return 两个参数的商
*/
public static double div(double v1, double v2, int scale) {
if (scale < 0) {
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}2015-09-30
int 除法得整数
int i =1;
int j =2;
int x = 1/2;
x=0;
double除法得小数

double i =1;
double j =2;
double x = 1/2;
x=0.5;2008-10-04
用Float类型就行了2008-10-04
你设置的数据类型是不是int的2008-10-04
mengvlog 阅读 53 次 更新于 2025-10-30 08:42:55 我来答关注问题0
  • 除法运算/的功能是有区别的。如果相除的两个数都是整数,那么结果也是整数,这叫做取整除法。比如,3/2,结果是1。如果其中有一个是浮点数,那么就是浮点除法,结果是浮点数,比如,3.0/2,结果是1.5.

  • 在Java编程语言中,当我们处理整数除法时,经常会遇到一些意外的结果。例如,当我们用1除以2时,得到的结果并不是0.5,而是0。这是因为Java默认的整数除法会直接舍去小数部分,而非四舍五入。具体来说,当两个整数进行除法运算时,结果同样是整数,小数部分会被自动截断。这个特性在实际编程中可能会导致...

  • 当除数为零时,Java会抛出一个ArithmeticException异常。这是因为在实际的数学运算中,除以零是没有意义的,也是无法计算的。因此,在进行除法运算时,确保除数不为零是非常重要的。为了避免这种情况,可以使用条件语句检查除数是否为零,或者在尝试进行除法运算时使用异常处理来捕获可能的异常。需要注意的是,...

  •  青鸟中关村专家 Eclipse的乘运算为什么是0?

    你问的是除法运算为什么是0吧。在Java中有两个“除法”:1)/:表示的是取整操作。比如10除3 等于3 余1,那么,10/3=3 。 结果只取整数部分。2)%:表示的是取余的操作。还是10除3 ,结果就是1 。所以,5/6=0

  •  翡希信息咨询 java中1%10=1,2%10=2当被除数比除数小的时候为什么余数为除数呢?

    在Java中,当被除数比除数小时,余数就是被除数本身,而不是除数。这是因为求余运算的数学定义决定的,与Java语言本身无关。以下是对此现象的详细解释:求余运算的定义:求余运算的结果是除法的余数。当被除数除以除数时,如果不能整除,则余数是除法的剩余部分。被除数小于除数的情况:如果被除数小于...

檬味博客在线解答立即免费咨询

Java相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部