Java中的变量绑定和关键字this
在下面的代码中,即使在运行时“this”引用类型为B的对象,getX()方法中的变量x如何绑定到类A实例的成员字段。这是在编译时还是在运行时发生的Java中的变量绑定和关键字this,java,Java,在下面的代码中,即使在运行时“this”引用类型为B的对象,getX()方法中的变量x如何绑定到类A实例的成员字段。这是在编译时还是在运行时发生的 class A { public void getX(){ Class cls = this.getClass(); System.out.println("The type of the object is: " + cls.getName()); System.out.format("
class A {
public void getX(){
Class cls = this.getClass();
System.out.println("The type of the object is: " + cls.getName());
System.out.format("value of x = %d\n", this.x);}
public int x = 0;
}
public class B extends A {
public static void main(String[] args) {
B obj = new B();
obj.getX();}
public int x = 1;
}
输出为:
The type of the object is: B
value of x = 0
字段不以多态方式解析。在编译时,
this.x
被静态解析为“获取类A中定义的字段x的值”。字段可以被子类隐藏。字段x
不是静态字段,因此访问不是静态的。是的,那又怎样?它们是隐藏的,而不是被覆盖的,这正是显示0而不是1的原因。我没有说访问是静态的。我说x不是多态解析的,而是静态解析的。正确答案。B.this
添加了内存,因此x保持在this
内存的同一位置。因此,如果“this.x”在编译时得到解析,那么“this”不引用当前对象?是被忽略了吗?好吧,我想我终于明白了。在编译时,当与变量一起使用时,此不引用当前对象,因为除了java语言规范所述之外,没有任何对象:其类型是类C,其中出现关键字this。。因此,上面getX()
中this
的类型是A类(@JB Nizet在他的帖子中提到,this的声明类型是A)。由于变量是在编译时静态绑定的,因此使用声明的类型this
。