直到今天,我还以为:

i += j;

只是一条捷径:

i = i + j;

但如果我们这样做:

int i = 5;
long j = 8;

则i=i+j;不会编译,但i+=j;将编译良好。

这是否意味着实际上i+=j;是这样的捷径吗i=(i的类型)(i+j)?


当前回答

在i=i+l的情况下,需要显式地从long转换为int,然后它将编译并给出正确的输出。喜欢

i = i + (int)l;

or

i = (int)((long)i + l); // this is what happens in case of += , dont need (long) casting since upper casting is done implicitly.

但在+=的情况下,它工作得很好,因为运算符隐式执行从右变量类型到左变量类型的类型转换,因此不需要显式转换。

其他回答

此处的微妙之处。。。

当j是double,i是int时,i+j有一个隐式类型转换。当整数之间有运算时,Java总是将整数转换为双精度。

为了澄清i+=j,其中i是整数,j是双精度,可以描述为

i = <int>(<double>i + j)

参见:隐式铸造的描述

为了清楚起见,在本例中可能需要将j类型转换为(int)。

使用*=或/=

byte b = 10;
b *= 5.7;
System.out.println(b); // prints 57

or

byte b = 100;
b /= 2.5;
System.out.println(b); // prints 40

or

char ch = '0';
ch *= 1.1;
System.out.println(ch); // prints '4'

or

char ch = 'A';
ch *= 1.5;
System.out.println(ch); // prints 'a'

Yes,

基本上当我们写作时

i += l; 

编译器将其转换为

i = (int)(i + l);

我刚检查了.class文件代码。

知道这真是件好事

在Java中,当赋值操作右侧的表达式类型可以安全地升级为赋值左侧的变量类型时,自动执行类型转换。因此,我们可以安全地分配:

 byte -> short -> int -> long -> float -> double. 

反之亦然。例如,我们不能自动将long转换为int,因为第一个比第二个需要更多的存储空间,因此信息可能会丢失。为了强制进行这样的转换,我们必须执行显式转换。类型-转换

有时候,这样的问题可以在面试中提出。

例如,当您写:

int a = 2;
long b = 3;
a = a + b;

没有自动打字。在C++中,编译上述代码时不会出现任何错误,但在Java中,您会遇到类似“不兼容类型异常”的情况。

因此,为了避免这种情况,您必须像这样编写代码:

int a = 2;
long b = 3;
a += b;// No compilation error or any exception due to the auto typecasting