1. boolean不参加转换
2.显示转换 (强制类型转换)
A:从大到小
B:可能会有精度的损失,一般不建议这样使用。
C:格式:
目标数据类型 变量名 = (目标数据类型) (被转换的数据);
3.隐式转换:
A:从小到大
B:byte,short,char -- int -- long -- float -- double
C:byte,short,char之间不相互转换,直接转成int类型参与运算。
eg:
A:下面两种方式有区别吗?
float f1 = 12.345f;//本身就是浮点数 不存在转换
float f2 = (float)12.345;//存在转换:将double转换为float;大转小须强转
区别:存在强转
B:下面的程序有问题吗,如果有,在哪里呢?
byte b1 = 3;
byte b2 = 4;
byte b3 = b1 + b2;//byte=byte+byte
byte b4 = 3 + 4;//byte=int+int;大转小存在强转 转成int-->byte
C:下面的操作结果是什么呢?
byte b = (byte)130;//将int类型强转为byte
D:字符参与运算
是查找ASCII里面的值
'a' 97
'A' 65
'0' 48
System.out.println('a');
System.out.println('a' + 1);
E:字符串参与运算
这里其实是字符串的连接
System.out.println("hello"+'a'+1);
string+char+int------>string+string+string
resoult:"helloa1"//字符串相加
System.out.println('a'+1+"hello");
char+int+hello-------->int+int+string----->('a'=97)+1+"hello"
resoult:"98hello"//‘a’表示的的ASCII值就是97 +1+“hello”
System.out.println("5+5="+5+5);
string+int+int------>string+string+string
resoult:5+5=55
System.out.println(5+5+"=5+5");
int+int+string-------->int+int+string
resoult:10=5+5
规律:输出格式 跟第一个“+”数据格式有关
其他问题:
1:在定义Long或者Float类型变量的时候,要加L或者f。
整数默认是int类型,浮点数默认是double。
byte,short在定义的时候,他们接收的其实是一个int类型的值。
这个是自己做了一个数据检测的,如果不再它们的范围内,就报错。
2:byte值的问题
byte b1 = 127;
byte b2 = (byte)128; //-128
byte b3 = (byte)129; //-127
byte b4 = (byte)130; //-126
byte的范围:-128 ~ 127
128:10000000
-128:10000000 (这里的1即是符号位,也是数值位)
3:数据类型转换之默认转换
byte,short,char -- int -- long -- float -- double
long: 8个字节
float:4个字节
A:它们底层的存储结构不同。
B:float表示的数据范围比long的范围要大
long:2^63-1
float:3.4*10^38 > 2*10^38 > 2*8^38 = 2*2^3^38 = 2*2^114 > 2^63-1
4:Java语言中的字符char可以存储一个中文汉字吗?为什么呢?
可以。因为java语言中的字符占用两个字节。
Java语言采用的是Unicode编码。