从超类访问阴影变量

Access shadowed variables from superclasses

从这个anwser,他说我们可以通过强制转换this从超类的超类访问阴影变量,但它不适用于方法调用,因为方法调用是根据对象的运行时类型。

但是,为什么我仍然可以在不显式转换传递参数类型的情况下获得隐藏变量?

interface I { int x = 0; }
class T1 implements I { int x = 1; }
class T2 extends T1 implements I { int x = 2; }
class T3 extends T2 implements I {
    int x = 3;

    void test() {
        System.out.println("((T3)this).x=" + ((T3)this).x + "; getT3(this)=" + getT3(this));
        System.out.println("((T2)this).x=" + ((T2)this).x + "; getT2(this)=" + getT2(this));
        System.out.println("((T1)this).x=" + ((T1)this).x + "; getT2(this)=" + getT1(this));
        System.out.println("((I)this).x=" + ((I)this).x + "; getI(this)=" + getI(this));
    }

    public static void main(String[] args) {
        new T3().test();
    }

    int getT3(T3 t3) { return t3.x; }
    int getT2(T2 t2) { return t2.x; }
    int getT1(T1 t1) { return t1.x; }
    int getI(I i) { return i.x; }
}

产生输出:

((T3) this).x = 3; getT3(this) = 3
((T2) this).x = 2; getT2(this) = 2
((T1) this).x = 1; getT1(this) = 1
((I) this).x = 0; getI(this) = 0

如果我正确理解他的答案,getT3getT2getT1getI 方法不应该都是 return 3 吗?

因为方法签名需要 IT1T2T3,所以当 returning i.x, t1.x, 等等

所以调用 getT2(this) 本质上等同于调用 getT2((T2) this).

这就是为什么他们不会全部 return 3,而是 x 该特定类型的值。

我不确定我是否解释得很好,但是因为 T3 扩展了 T2,它在传递给 [=22] 时隐式转换为 T2 的实例=].