Kotlin 中用于内部 类 的变量阴影:如何解析变量?

Variables shadowing in Kotlin for inner classes: how variables are resolved?

我在 Kotlin 中有以下代码片段。我喜欢这样的代码谜题,但是这里的结果对我来说太出乎意料了。有人能告诉我为什么它打印 1 而不是 2 吗?

由于阴影在 Java 中被禁止 - 看起来我完全不明白它在 Kotlin 中是如何工作的。

fun main() {
    var a = 1
    class A {
        var a = 2

        fun foo() = a
    }

    println(A().foo())
}

=========== 奖金 ============

有趣的是,当您在 class 声明之后移动 var a = 1 时,以下代码工作正常并打印 2:

fun main() {
    
    class A {
        var a = 2

        fun foo() = a
    }

    var a = 1
    println(A().foo())
}

UPD:看起来 Kotlin 突然决定像 C++ 一样玩并且有未定义的行为:D

来自 Kotlin specuse this with caution, because in some cases it can be called instead

当您在 class A 中执行 var a = 2 时,您实际上并没有隐藏任何变量 。您声明 a 是 class A 字段 ,并且默认为 2.

当你在 class 前面引用一个变量时,如果有一个字段带有该名称 但不是具有该名称的上层变量 。因此,外部 a 优先于该字段,您必须使用 this.a 访问内部 a.