就我的理解而言,在Kotlin中委托实现的想法是为了避免出现类似于以下内容的代码:
class MyClass(val delegate : MyInterface) : MyInterface
{
override fun myAbstractFun1() = delegate.myAbstractFun1()
override fun myAbstractFun2() = delegate.myAbstractFun2()
// ...
}
相反,我们可以编写以下代码,该代码也应该执行相同的操作:
class MyClass(val delegate : MyInterface) : MyInterface by delegate
现在,我希望delegate
是一个可变变量,即我的代码如下所示:
var delegate : MyInterface = MyImplementation()
object MyObject : MyInterface by delegate
因此,如果Id自己将每个抽象方法委托给delegate
,就像在第一个示例中一样,更改delegate
的值确实会更改方法的行为。但是,上面的代码编译成这段Java代码:
public final class MyObject implements MyInterface {
public static final MyObject INSTANCE;
// $FF: synthetic field
private final MyInterface $$delegate_0 = MyObjectKt.access$getDelegate$p();
@NotNull
public String myAbstractFun1() {
return this.$$delegate_0.myAbstractFun1();
}
@NotNull
public String myAbstractFun2() {
return this.$$delegate_0.myAbstractFun2();
}
}
因此,显然,Kotlin编译器不只是使用delegate
字段,而是决定在创建myobject
时将其复制到最终字段$$delegate_0
中,当我更改delegate
的值时,该字段不会被修改
有没有更好的解决方案来实现这一点,而不是手动委托每个方法?
遗憾的是,据我所知,无法通过更改原始属性内容来更改委托,但您仍然可以通过以不可变的方式工作并复制对象来执行类似的操作:
interface MyInterface {
fun foo():Int
}
data class MyClass(val delegate : MyInterface) : MyInterface by delegate
object ImplementationA: MyInterface { override fun foo() = 7 }
object ImplementationB: MyInterface { override fun foo() = 5 }
val objA = MyClass(ImplementationA)
println(objA.foo()) // returns 7
val objB = objA.copy(ImplementationB)
println(objB.foo()) // returns 5
println(objA.foo()) // still 7
希望这还有用。
主要内容:类委托,属性委托,标准委托,可观察属性 Observable,把属性储存在映射中,Not Null,局部委托属性,属性委托要求,翻译规则,提供委托委托模式是软件设计模式中的一项基本技巧。在委托模式中,有两个对象参与处理同一个请求,接受请求的对象将请求委托给另一个对象来处理。 Kotlin 直接支持委托模式,更加优雅,简洁。Kotlin 通过关键字 by 实现委托。 类委托 类的委托即一个类中定义的方法实际是调用另一个类的对象的方法来实现的。 以下实例中派生类 Derived 继承了接口
委托模式是软件设计模式中的一项基本技巧。在委托模式中,有两个对象参与处理同一个请求,接受请求的对象将请求委托给另一个对象来处理。 Kotlin 直接支持委托模式,更加优雅,简洁。Kotlin 通过关键字 by 实现委托。 类委托 类的委托即一个类中定义的方法实际是调用另一个类的对象的方法来实现的。 以下实例中派生类 Derived 继承了接口 Base 所有方法,并且委托一个传入的 Base 类的
假设我有一个JPA实体,比如 现在,我知道对于联接表中的每一个条目,这些属性都不能为空。(事实上,数据库强制执行此操作。) 好吧,让我们使用建议的解决方案,并转换为使用委托。 这仍然不能编译,因为 此批注不适用于目标“带有委托的成员属性” 我如何解决这个问题?
下面是我在gradle的留档https://docs.gradle.org/current/userguide/tutorial_using_tasks.html中发现的代码片段 在上面,hello是提供任务定义/操作的TaskProvider类型。对hello的第二个调用是扩展任务的行为。 这个委托使用看起来有点让我困惑。以下是困扰我的问题: 1) 在检查反编译的字节码时,我看到了任务。注册返回
Kotlin具有委托属性,这是一个非常好的特性。但我正在研究如何获取和设置这些值。假设我想得到委托的财产的价值。在get()方法中,如何访问该值? 这是我如何实施的一个例子: 我无法理解的主要问题是,我如何将值设置为委托类被分配到的实际属性。当我将“NEW”赋给属性< code>p时,如何将该值存储到变量< code>p中,或者使用get读取传递给< code>p的新值?我是不是错过了一些基本的东