java面试题002

1、判断下列代码的运行情况

public class TestExtends {
    public static void main(String[] args) {
        Father obj = new Son();
        System.out.println(obj.getEle());
    }
}

class Father{
    public int getEle(){
        return 1;
    }
}
class Son extends Father{
    public float getEle(){
        return 2f;
    }
}

答案:编译出错。原因是函数不能以返回值来区分,虽然父类与子类中的函数有着不同的返回值,但是它们有着相同的函数名,因此编译器无法区分。

2、抽象方法权限标识只能由public or protected修饰【注:可以不进行权限修饰-为default】。

3、接口中的方法只能由public,abstract修饰。

4、内部类都有哪些,它们的特性分别是什么?

内部类分为四种:静态内部类、成员内部类、局部内部类和匿名内部类。

①静态内部类被static修饰,可以不依赖外部实例而被实例化,不能和外部类有相同的名字,不能访问外部类的非静态成员。

②成员内部类可以自由的引用外部成员变量和方法(包括私有)

③局部内部类不能被public等权限修饰符及static修饰

④匿名内部类不能使用class、extends、implements,没有构造函数,必须继承类或者实现接口,由此只能创建一个匿名内部类实例。另外局部内部类约束同样适用匿名内部类。

5、如何获取父类的类名?

答:使用getClass().getSuperclass().getName()。

:为什么不能使用super.getClass().getName(),解释如下:

getClass()方法在Object类中被定义为final和native,子类不能覆盖该方法。所以this.getClass()和super.getClass()都是调用了Object的getClass(),而Object的getClass的释义是返回Object的正在运行的类。

6、为什么要有super关键字?

对于子类集成父类的例子中,如果子类覆盖了父类的方法,如果想要调用父类原来的方法就必须使用super进行调用。

7、super错误使用样例:

class Father{
    public Father(){
        System.out.println("老爸在这");
    }
}
class Son extends Father{
    public Son(){
        System.out.println("儿子在这~");
        super();
    }
}

解释:会出现编译错误,super()必须为子类构造函数中的第一条语句。

8、值传递和引用传递的区别有哪些?

值传递:在方法调用中,实参会把它的值传递给形参,形参只是用实参的值初始化一个临时存储单元,因此形参与实参虽然有着相同的值,却是不同的存储单元,因此对形参的改变不会影响实参的值。

引用传递:在方法调用中,传递的是对象【的地址】,这时形参与实参指向的存储单元相同,因此会影响实参的值。 

看下面一段代码,是否有疑惑呢?

    public static void main(String[] args) throws InstantiationException, IllegalAccessException {
        StringBuffer s1 = new StringBuffer("Hello ");
        StringBuffer s2 = new StringBuffer("Hi ");
        changeSB(s1,s2);
        System.out.println(s1);
        System.out.println(s2);
        
    }

    private static void changeSB(StringBuffer s1, StringBuffer s2) {
        s1.append("Kevin");
        s2 = s1;
        System.out.println("method inner"+s2);
    }

代码输出结果为:

method innerHello Kevin
Hello Kevin
Hi

这里是按值传递的,append方法会修改ss1所指向字符串的值,而执行changeSB中的ss2=ss1只会修改ss2的值而不会修改s2的值。

9、运算符优先级

括号 > 正负符号、自运算、取反、非 > 算术运算 > 位运算 > 比较逻辑运算 > 判等逻辑运算 > 逻辑与、或、异或 > 逻辑双 与、或 > 三目运算 > 赋值运算 、运算赋值运算

 10、判断下面代码输出的结果

1         String s1 = "abc";
2         String s2 = "abc";
3         String s3 = new String("abc");
4         System.out.println("s1==s2? "+(s1==s2));
5         System.out.println("s1==s2? "+s1==s2);
6         System.out.println("s1==s3? "+(s1==s3)); 

输出结果如下:

s1==s2? true
false
s1==s3? false

解释:①s1和s2指向常量池中的同一个字符串常量;②首先执行了字符串+运算[优先级问题]③new出来的对象都会在堆中开辟内存空间,所以s1和s3指向不同,这里使用equals方法判断值相等。

 

posted @ 2018-05-24 10:40  赤子说  阅读(158)  评论(0编辑  收藏  举报