注意:java是强类型语言,变量必须先定义再使用。
一、数据类型:
==基本类型==:
数值类型:
整数类型:byte(1字节)、short(2字节)、int(4字节)、long(8字节)
浮点类型:float(4字节)、double(8字节)
字符类型:char(2字节)
boolean类型:占1位 只有true和false
==引用类型==:
类
接口
数组
二、浮点数细节:
1.由于float double 有限 离散 舍入误差 接近但不等于,所以浮点数在比较时容易出现错误,如下。
float f = 0.1f;
double d = 1.0 / 10;
System.out.println(f == d); //false
float d1 = 22213131313131f;
double d2 = d1 + 1;
System.out.println(d1 == d2); //true
2.最好避免完全用浮点数进行比较。
3.可以用BigDecimal 数学工具类 去表示再比较。
三、强制类型转换:
注意:低---------------------------------->高
byte,short,char->int->long->float->double
1.不能对布尔进行转换
2.不能把对象类型转为不相干的类型
3.把高容量转为低容量需要强制转换
4.转换的时候可能内存溢出,或精度问题
1.字符的本质就是数字
char c1 = 'a';
char c2 = '中';
int x = (int)c1; //97
int y = (int)c2; //20013
可查Unicode表。
2.强制转换 (类型)变量名 高->低
int i = 128;
byte b = (byte)i; //内存溢出 -128-127
3.自动转换 低->高
double c = i;
char d = 'a';
int e = d + 1;
4.操作大数可能溢出
int m = 1000000000;
int y = 20;
int t = m * y; //-1474836480 计算时已经溢出
long tt = m * y; //m * y时已经默认是int类型了,所以已经溢出了,再转为long时还是溢出的
long ttt = m * (long)y; //不溢出