通过查漏补缺,查看自身对知识点的理解是否有误。知识点会比较松散,待梳理之后再次更新。如果有不对的地方,欢迎指正!
java基础部分
基础数据类型
各个类型占用的字节数一览
java采用的uincode编码,由于其JVM具有跨平台性因此java在32位和64位机下基本数据类型占字节数是一致的(这样才能达到跨平台通信)。C/C++就不是这样的,因此不能一概而论。
类型 | 占用字节 | 占用位数 |
---|---|---|
byte | 1 | 8 |
short | 2 | 16 |
int | 4 | 32 |
long | 8 | 64 |
float | 4 | 32 |
double | 8 | 64 |
char | 2 | 16 |
boolean | 1 | 8 |
1. int是基本数据类型Integer不是,它是对象,是int的包装类。
int和Integer关系概述:
1.int是基本的数据类型;
2.Integer是int的封装类;
3.int和Integer都可以表示某一个数值;
4.int和Integer不能够互用,因为他们两种不同的数据类型;
2. 关于Integer还需要注意的是:
用Integer指向-128到127之间的数,Java会对其进行缓存。而超出这个范围则新建一个对象。
也就是说
Integer c = 100;
Integer d = 100;
System.out.println((c == d)); //true
Integer a = 128;
Integer b = 128;
System.out.println((a == b)); //false,这两个已经是两个新的对象
3. 其他类型向int类型转换
- 没有final修饰的变量相加后会被自动提升为int型,与目标类型byte不相容,需要强制转换(向下转型)
- Java中涉及到byte、short和char类型都可以强制转化为int
- 低精度往高精度转化顺序(short/char)->int->unsigned->long->double<-float
举两个栗子:
- char c,short s,float f,double d,表达式c*s+f+d的结果类型为 double。
理由概况为低精度往高精度转。(short/char)->int->unsigned->long->double<-float
全场最高精度是double所以最后的值类型为double。- (short)10/10.22与(short) (10/10.22),前者只是把10强转为short,又由于式子中存在浮点数,所以会对结果值进行一个自动类型的提升,浮点数默认为double。后者才是把值强转为short。
4. 浮点数默认的数据类型是double
如果要使用float,需要在值后加f。