如何在父上下文中创建变量

时间:2016-05-31 18:51:25

标签: kotlin kotlin-extension

我试图在Kotlin中实现类似于这种语法的东西

class MyClass() {
    fun before(init: () -> Unit): Unit {
        with(this) init
    }
    fun after(block: () -> Unit): Unit {
        with(this) block
    }
}

fun main () {
    var myClass = MyClass()
    myClass.before {
        var a = 5
    }
    myClass.after {
        println("Double of a is ${a * 2}")
    }
}

现在,由于a无法在after内解决,因此无法解决问题。我知道这是由于闭包的工作方式。

我的问题是,如果Kotlin中有一些机制允许我这样做,那么在闭包/扩展中创建变量,使它们存储在接收器对象中,并且可以被其他闭包/扩展访问。

这是将Groovy脚本迁移到Kotlin的努力的一部分。

免责声明:这是我第一次去Kotlin。我已经阅读了文档,但我可能会遗漏一些东西(很多)。随意指向正确的方向

编辑:添加可编辑的示例

class Aa() {

    var a: Int = 0
    var bb: () -> Unit = null!!

    fun ww (block: () -> Unit) {
        bb = block
    }

    fun doit(block: () -> Unit) {
        with(bb) {
            block()
        }
    }

}

fun main(args: Array<String>) {
    val exec = fun Aa.(other: () -> Unit): Unit = other()

    aa.ww {
        var xx = 5
    }

    aa.doit {
        // println("with $xx") <- this fails
    }
}

1 个答案:

答案 0 :(得分:1)

Kotlin是一种静态类型语言。无法将数据存储在该对象内没有字段的对象实例中。

您可以定义类型为Map的属性,并将值存储在该映射中,但除非您事先知道哪些值将存储在那里,否则您将无法使用常规属性语法访问它们