我有一个叫做类的类Entity,它是abstract我在整个程序中使用的许多其他对象的超类(对于这个例子,Apple类).
在许多方法中,我通过打印打印语句的类名来打印调试语句,然后是实际的调试消息.然而,令我惊讶的是,当我从一个实例调用继承的方法时Apple,Apple打印的是类名而不是类名Entity(这是方法实际所在的位置).
为了获得一个更容易发布代码片段的相关示例,我已经覆盖了toString()这样:
public abstract class Entity {
private String name;
@Override
public String toString() {
return getClass().getSimpleName() + " " + (name != null ? name : super.hashCode());
}
}
Run Code Online (Sandbox Code Playgroud)
因为我没有在Apple类中进一步覆盖此方法,我希望返回的String的第一部分Entity不是Apple.然而它又返回了Apple(对于这个用例来说,它实际上很好用,但仍然有点令人费解).
我尝试查看实现Object#getClass(),但无法将其声明为native方法.
public final native Class<?> getClass();
谁能解释为什么会这样?
你在打电话getClass().它总是返回对与Class对象的实际执行时类型相关联的对象的引用,而不是对其调用它的表达式的编译时类型的类.例如:
Object foo = "this is a string";
Class<?> clazz = foo.getClass();
Run Code Online (Sandbox Code Playgroud)
clazz将引用类String,而不是类Object.
你并不需要看落实的getClass()-只是看看文档:
Class对象,表示此对象的运行时类.
请注意"运行时"位,如"在执行时确定,而不是在编译时".
在这种情况下,我认为在结果中返回执行时类名是完全合理的toString(),但是如果你真的真的想要这个Entity类,你可以Entity.class改用它.
| 归档时间: |
|
| 查看次数: |
918 次 |
| 最近记录: |