java 中加法赋值运算符(+=)的问题
classNoname2{publicstaticvoidmain(String[]args){inta=1;intb=1;for(inti=1;i<=1;i++){a+...
class Noname2 {
public static void main(String[] args)
{
int a=1;
int b=1;
for (int i=1;i<=1 ;i++ )
{
a+=2.0;
}
System.out.println("a="+a);
b+=2.0;
System.out.println("b="+b);
}
}
为什么结果a和b的值都是3,a为什么不是3.0? 展开
public static void main(String[] args)
{
int a=1;
int b=1;
for (int i=1;i<=1 ;i++ )
{
a+=2.0;
}
System.out.println("a="+a);
b+=2.0;
System.out.println("b="+b);
}
}
为什么结果a和b的值都是3,a为什么不是3.0? 展开
3个回答
展开全部
因为 a,b都是int类型 a+=2.0 相当于 a= a+2.0,系统会默认将2.0变成2,ni 你可以试一试2.1应该还是一样的
追问
int a=1;
a=a+2.0;
System.out.println("a="+a);
如果写成以上代码,编译的时候会提示“可能损失精度”,因为a+2.0是double类型的。但是写成a+=2.0,就能够编译通过。
这是为什么了?
追答
java的基本类型会有转型这个说法的,有自动转型,和强制转型。你的第一中写法相当于给一个int的a赋值一个double多以会提示可能损失精度,但是 a+=2.0虽然相当于a=a+2.0;但是和它是不一样的,系统会自动转型的。
展开全部
a和b是int的整数型所以结果也是int整数型,你要小数的话就生成double的
追问
int a=1;
a=a+2.0;
System.out.println("a="+a);
如果写成以上代码,编译的时候会提示“可能损失精度”,因为a+2.0是double类型的。但是写成a+=2.0,就能够编译通过。
这是为什么了?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
因为你的a和b都是int型的啊
追问
int a=1;
a=a+2.0;
System.out.println("a="+a);
如果写成以上代码,编译的时候会提示“可能损失精度”,因为a+2.0是double类型的。但是写成a+=2.0,就能够编译通过。
这是为什么了?
追答
你直接写a+2.0这个的结果却是是double
但
a = a+2.0的结果就是int的了,因为前者计算结束后没有将计算结果付给其他变量,后者因为赋值给一个int类型的变量所以结果就是int类型的了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询