Java中的变量绑定和关键字this

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("

在下面的代码中,即使在运行时“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("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