自动拆箱装箱
jdk1.5后下列程序输出结果为.
int i=0; Integer j = new Integer(0); System.out.println(i==j); System.out.println(j.equals(i));
本题是一个自动拆装箱的考题(自动拆装箱JDK需在1.5上),下面的讨论都不针对新开辟对象的情况:
1、基本型和基本型封装型进行“==”运算符的比较,基本型封装型将会自动拆箱变为基本型后再进行比较,因此Integer(0)会自动拆箱为int类型再进行比较,显然返回true;
2、两个Integer类型进行“==”比较,如果其值在-128至127,那么返回true,否则返回false, 这跟Integer.valueOf()的缓冲对象有关,这里不进行赘述。
3、两个基本型的封装型进行equals()比较,首先equals()会比较类型,如果类型相同,则继续比较值,如果值也相同,返回true
4、基本型封装类型调用equals(),但是参数是基本类型,这时候,先会进行自动装箱,基本型转换为其封装类型,再进行3中的比较。int a=257; Integer b=257; Integer c=257; Integer b2=57; Integer c2=57; System.out.println(a==b); //System.out.println(a.equals(b)); 编译出错,基本型不能调用equals() System.out.println(b.equals(257.0)); System.out.println(b==c); System.out.println(b2==c2);
因此上面的代码的结果因此为 true, false, false, true
以下哪些代码能正确执行
byte a = 3; byte b = 2; b = a + b;//第一段 byte a = 127; byte b = 126; b = a + b;//第二段 byte a = 3; byte b = 2; a+=b;//第三段 byte a = 127; byte b = 127; a+=b;//第四段
byte类型的变量在做运算时被会转换为int类型的值,故A、B左为byte,右为int,会报错;而C、D语句中用的是a+=b的语句,此语句会将被赋值的变量自动强制转化为相对应的类型:+=会自动强转(自动装箱功能),但是+必须要手动强转b=(byte)(a+b)
抽象类、接口访问权限
关于抽象类
JDK 1.8以前,抽象类的方法默认访问权限为protected
JDK 1.8时,抽象类的方法默认访问权限变为default
(java1.8实测,抽象类中的抽象方法和非抽象方法在不加修饰符的情况下,都是默认的default)
关于接口
JDK 1.8以前,接口中的方法必须是public的
JDK 1.8时,接口中的方法可以是public的,也可以是default的
JDK 1.9时,接口中的方法可以是private的
类方法
A 在类方法中可用this来调用本类的类方法
B 在类方法中调用本类的类方法时可直接调用
C 在类方法中只能调用本类中的类方法
D 在类方法中绝对不能调用实例方法
A C D
首先:
成员方法又称为实例方法
静态方法又称为类方法
其次:
a,静态方法中没有this指针()
c,可以通过类名作用域的方式调用Class::fun();
d,太绝对化了,在类中申请一个类对象或者参数传递一个对象或者指针都可以调用;