Why can not I add two bytes and get an int and I can add two final bytes get a byte?
From the JLS 5.2 Assignment Conversion
In addition, if the expression is a constant expression (§15.28) of type byte, short, char, or int: - A narrowing primitive conversion may be used if the type of the variable is byte, short, or char, and the value of the constant expression is representable in the type of the variable.
In short the value of the expression (which is known at compile time, because it is a constant expression) is representable in the type of the variable that is byte.
Consider your expression
final byte x = 1;
final byte y = 2;
byte z = x + y;//This is constant expression and value is known at compile time
So as summation fits into byte it does not raise an compilation error.
Now if you do
final byte x = 100;
final byte y = 100;
byte z = x + y;// Compilation error it no longer fits in byte
byte z = x + y; // x and y are declared final
Here, since x
and y
are declared final
so the value of expression on the RHS
is known at compile time, which is fixed at (1 + 2 = 3)
and cannot vary. So, you don't need to typecast it explicitly
byte c = a + b; // a and b are not declared final
Whereas, in this case, value of a
and b
are not declared final. So, the value of expression is not known at compile time, rather is evaluated at runtime. So, you need to do an explicit cast.
However, even in the 1st code, if the value of a + b
comes out to be outside the range -128 to 127
, it will fail to compile.
final byte b = 121;
final byte a = 120;
byte x = a + b; // This won't compile, as `241` is outside the range of `byte`
final byte b1 = 12;
final byte a1 = 12;
byte x1 = a1 + b1; // Will Compile. byte can accommodate `24`