package com.baidu.www.Scanner;
/*
对于byte/short/char三种类型来说,如果右侧赋值的数字没有超过范围,
那么JAVAc编译器将会自动隐含的为我们补上一个(byte)(short)(char).
1.如果没有超过左侧的范围,编译器补上强转。
2.如果右侧超过了左侧范围,那么直接编译器报错。
*/
public class Demo16 {
public static void main(String[] args){
//右侧确实是一个int数字,但是没有超过左侧范围,就是正确的。
//int -->byte,不是自动类型转换
byte num1 = /*(byte)*/30;// 右侧没有超过左侧范围
System.out.println(num1);//30
//int-->char,没有超过范围
//编译器将会自动补上一个隐含的(char)
char num2 = /*(char)*/65;
System.out.println(num2);// A
}
}
package com.baidu.www.Scanner;
/*
在给变量进行赋值的时候,如果右侧的表达式当中全是常量,没有任何变量
那么编译器javac将会直接将若干个常量表达式计算得到结果。
short result = 5 + 8;// 等号右边全都是常量,没有任何变量参与运算。
编译之后,得到.class字节码文件当中相当于{直接就是}:
short result = 13;
右侧的常量结果数值,没有超过左侧范围,所以正确。
这称为”编译器的常量优化“。
但是注意:一旦表达式变量参与,那么就不能进行这种优化了。
*/
public class Demo17 {
public static void main(String[] args) {
short num1 = 10;
short a = 5;
short b = 8;
// short + short--> int + int -->int
//short result = a + b; 错误写法!左侧需要int
//右侧不用变量,而是采用常量,而且是两个常量。没有别人
short result = 5 + 8;
System.out.println(result);
//short result2 = 5 + a + 8 ;错误
}
}