下面的程序是否存在问题?如果存在,请指出问题所在;如果不存在,书名输出结果
package com.interview.test;
class TestSuper{}
public class TestClass_201808 extends TestSuper{
public static void main(String[] args) {
TestClass_201808 t = new TestClass_201808();
t.test();
}
public void test() {
System.out.println(super.getClass().getName());
}
}
答案:com.interview.test.TestClass_201808(包名.类名)
分析:
解答这题,首先需要明确getClass()方法。getClass()方法继承自Object类,是一个final的本地方法,官方文档翻译如下:
返回此 Object 的运行时类。返回的 Class 对象是由所表示类的 static synchronized 方法锁定的对象。
实际结果类型是 Class<? extends |X|>,其中 |X| 表示清除表达式中的静态类型,该表达式调用 getClass。 例如,以下代码片段中不需要强制转换:
Number n = 0;
Class<? extends Number> c = n.getClass();
可以看出,getClass()方法返回的是当前运行时的类,而在上面的代码中实际运行的类是TestClass_201808,而不是TestSuper,因此程序的输出结果为com.interview.test.TestClass_201808(全路径)
思考:
1.既然Object类的getClass()方法是final的,那么所有的getClass()都遵循相同的逻辑。因此在类中使用super.getClass().getName()和this.getClass().getName()获取的结果是相同的,都是当前运行时的类(父类为abstract时也适用);
2.那么在子类中如何获取父类的名字呢,有两种方法,第一种,可以通过反射机制,使用getClass().getSuperclass().getName()获取;第二种,使用SuperClassName.class获取(父类为abstract时也适用);
package com.interview.test;
class TestSuper{}
public class TestClass_201808 extends TestSuper{
public static void main(String[] args) {
TestClass_201808 t = new TestClass_201808();
t.test();
t.test1();
t.getSuperClassName1();
t.getSuperClassName2();
}
//com.interview.test.TestClass_201808
public void test() {
System.out.println(super.getClass().getName());
}
//com.interview.test.TestClass_201808
public void test1() {
System.out.println(this.getClass().getName());
}
//com.interview.test.TestSuper
public void getSuperClassName1() {
System.out.println(getClass().getSuperclass().getName());
}
//com.interview.test.TestSuper
public void getSuperClassName2() {
System.out.println(TestSuper.class.getName());
}
}
3。如果子类实现的是接口,那么getClass().getSuperclass().getName()返回的是Object;
package com.interview.test;
interface TestSuper{
}
public class TestClass_201808 implements TestSuper{
public static void main(String[] args) {
TestClass_201808 t = new TestClass_201808();
t.getSuperClassName1();
}
public void getSuperClassName1() {
System.out.println(getClass().getSuperclass().getName());//java.lang.Object
System.out.println(getClass().getInterfaces()[0].getName());//com.interview.test.TestSuper
}
}
4.当父类持有子类的对象时,即TestSuper t = new TestClass_201808(),结果同上;