一.关于final
定义:修饰常量的关键字,注意常量一旦被定义,它的值就会被机器记住将无法修改;还有被final修饰的变量除了值不能改,变量的数据类型也不能修改。
final byte a=10;
因为final的修饰存储的b变量仍然的byte类型
二.数据类型的默认值
默认值
数值型:byte<short<int<long 0
浮点型: float<double 0.0
字符型:char \u0000(占位符)
布尔型:boolean false
引用类型:数组,类和接口 null
*注意在java中所有数据类型都有默认值,定义之后没有赋值的变量也会有默认值(只存在于类变量中,方法变量中的局部变量不存在默认值)
public class example1 {
int a;
char b;
float c;
boolean d;
public static void main(String[] args) {
System.out.println(new example1().a);
System.out.println(new example1().b);
System.out.println(new example1().c);
System.out.println(new example1().d);
}
}
执行的结果:
0
0.0
false
Process finished with exit code 0
三.数据类型的转换
在计算机保存数据中会把小于4字节的像byte,short,char,提升为int类型(cpu读写数据时,以四字节为单位进行读取,写入);当byte类型保存区间内的整数赋值给byte时,可以直接赋值,超出byte范围仍需强制类型转化。
下面是我常犯的错误希望大家引以为戒:
1).
byte a=120;
byte b=130;
system.out.println(a);//正确打印
system.out.println(b);//打印出错
超出byte的最大存储范围
2).
int a=120;
byte b=a;
system.out.println(a);//打印出错
需要强转
3).
int a=Integer.MAX_VALUE;
long b=a+1;
system.out.println(b);//此时long存储的b变量数据也会溢出
为什么会出现这种情况呢?
要知道程序执行代码都是从右到左,在这个程序中会先进行运算a+1此时就已经溢出了,那么long就存储了一个溢出值,打印b的值就会得到一个溢出的错误输出。
这些地方都需要我们注意,希望大家多多留心。如果有什么地方有错误或者是补充也欢迎大家指教。