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、判断下面代码输出的结果
String s1 = "abc";
String s2 = "abc";
String s3 = new String("abc");
System.out.println("s1==s2? "+(s1==s2));
System.out.println("s1==s2? "+s1==s2);
System.out.println("s1==s3? "+(s1==s3));
输出结果如下:
s1==s2? true
false
s1==s3? false
解释:①s1和s2指向常量池中的同一个字符串常量;②首先执行了字符串+运算[优先级问题]③new出来的对象都会在堆中开辟内存空间,所以s1和s3指向不同,这里使用equals方法判断值相等。