如下:
为了避免引起歧义,写详细点: 例一:
原因:应该是类型转换的问题 解释:double的类型比int大,他们两个相加应该会隐式转换为double类型,然后你用int类型的参数接收double类型的值的时候会有类型转换的异常 , 需要转换类型。
我想知道a+=b;与a=a+b;区别在哪?
a+=b 等价于 a = (int)(a+b), += 作为复合运算符会将结果强制转换为左边参数的类型, 并且a只会计算一次, a只会计算一次是什么意思?
int a=0;
double b=1.0;
a+=b;//不报错
a=a+b;//报错
什么原因?
为了避免引起歧义,写详细点: 例一:
int a=0;
double b=1.0;
a+=b;//不报错
例二:
int a=0;
double b=1.0;
a=a+b;//报错
我是想问a+=b;与a=a+b;区别在哪?
原因:应该是类型转换的问题 解释:double的类型比int大,他们两个相加应该会隐式转换为double类型,然后你用int类型的参数接收double类型的值的时候会有类型转换的异常 , 需要转换类型。
我想知道a+=b;与a=a+b;区别在哪?
a+=b 等价于 a = (int)(a+b), += 作为复合运算符会将结果强制转换为左边参数的类型, 并且a只会计算一次, a只会计算一次是什么意思?