自动拆箱装箱

  • 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,太绝对化了,在类中申请一个类对象或者参数传递一个对象或者指针都可以调用;