groovy – 如何在Trait中调用时正确使用闭包委托
发布时间:2020-12-14 16:27:23 所属栏目:大数据 来源:网络整理
导读:我有一个Groovy特性需要提供一个配置Closure作为库方法调用的参数(它是HttpBuilder,但它应该无关紧要). 为了重现这个问题,我创建了以下简单示例: trait T { def doIt() { return { n = 1 } }}class Delegate { int n}class Tish implements T { def go() {
我有一个Groovy特性需要提供一个配置Closure作为库方法调用的参数(它是HttpBuilder,但它应该无关紧要).
为了重现这个问题,我创建了以下简单示例: trait T { def doIt() { return { n = 1 } } } class Delegate { int n } class Tish implements T { def go() { def closure = doIt() def d = new Delegate() closure.delegate = d closure() assert d.n == 1 } } new Tish().go() 这应该没有错误地运行,因为当运行T trait中的doIt()方法返回的闭包时,它的委托被设置为可以将n变量设置为1的东西. 但是,这不起作用,我收到此错误: groovy.lang.MissingPropertyException: No such property: n for class: Tish 如果我让T成为一个类,让Tish扩展它,那么它的工作原理! 我尝试改变Closure的委托策略,但这没有帮助. 这是一个Groovy错误还是有办法解决这个问题? 解决方法
从中更改您的代码
def d = new Delegate() closure.delegate = d closure() 至 def d = new Delegate() closure.delegate = d closure.run() 这解决了一个非常类似的问题,我使用的是Grails 3.3.8,Groovy 2.4.15,Java 1.8.0_131.不知道为什么,但它有帮助. 我试图追逐错误并添加以下输出 println this println owner println delegate 并且发现在第一种情况下委托没有改变,甚至在执行closure()之前设置了closure.delegate = d!如果调用了closure.run(),则委托设置正确!?! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |