数据类型转换
当数据类型不一样时,将会发生数据转换
自动类型转换(隐式)
- 特点:代码不需要进行特殊处理,自动完成
- 规则:数据范围从小到大。(别忘了与字节数不一定相关)
强制类型转换(显式)
- 特点:代码需要进行特殊格式处理,不能自动完成
- 格式:范围小的类型 范围小的变量名 = (范围小的类型)原本范围大大的数据
注意事项
- 强制类型转换一般不推荐使用。因为有可能发生精度损失,数据溢出
- byte/short/char这三种类型都可以发生数学运算,例如加法“+”
- byte/short/char这三种类型在运算时都会首先被提升为int类型,然后再进行计算
- 布尔类型不能发生数字类型转换
public class test {
public static void main(String[] args){
System.out.println(1024); //这是一个整数,默认就是int类型
System.out.println(3.14); //这是一个浮点数,默认就是double类型
//左边是long类型,右边是默认int类型,左右不一样
//一个等号代表赋值,将右侧的int常量,交给左侧的long常量进行储存
//int --> long,符合数据范围从小到大的要求
//这一行代码发生了自动类型的转换
long num1 = 100;
System.out.println(num1); //100
//左边是double类型,右边是float类型,左右不一样
//float --> double,符合从小到大的规则
//也发生了自动类型的转换
double num2 = 2.5F;
System.out.println(num2); //2.5
//强制转换,左边是int 右边是long,不一样
//long -- > int 不是从小到大
//不能发生自动转换
//int num = 100L;
int num3 = (int)100L;
System.out.println(num3);
//long强制转换成int类型
int num4 = (int) 6000000000L;
System.out.println(num4); //1705032704 数据溢出
//double --> int 强制转换
int num5 = (int)3.5;
System.out.println(num5); //3 精度损失 不是四舍五入,所有的小数位都没了
char zifu1 = 'A'; //这是一个字符变量,里面是大写字母A
System.out.println(zifu1 + 1); //66,大写字母A被当作65进行处理
//计算机的底层会用一个数字(二进制)来代表字符A,就是65
//一旦char类型进行了数学运算,那么字符就会按照一点过的规律翻译一个数字
byte num6 = 40; //注意!右侧的数值大小不能超过左侧的类型范围
byte num7 = 50;
//byte + byte --> int 所以resul前面不能是byte应该是int
int result = num6 + num7;
System.out.println(result); //90
short num8 = 60;
//byte + short --> int + int --> int
//int强制转换为short,注意!必须保证逻辑上真是大小本来就没有超过short范围,否则数据会发生溢出
short resule2 = (short)(num6 + num8);
System.out.println(resule2); //100
}
}
数字和字符的对照关系表(编码表)
ASCII码表:美国信息交换标准代码
Unicode码表:万国码,也是数字和符号的对照关系,开头0-127部分和ASCII完全一样,但是从128开始包含更多字符
48 - ‘0’
65 - ‘A’
97 - ‘a’