当前位置: 首页 > news >正文

包头焦点网站建设腾讯云网站搭建

包头焦点网站建设,腾讯云网站搭建,怎么做英文版网站,手机网站制作相关文章Kotlin 委托本质—委托模式 在Kotlin中,可以用过by关键字很好的实现委托,而Kotlin中委托其实就是委托模式的实现,而委托模式已经被证明是实现继承的好方式,通过by关键字将接口的实现委托给另一个对象。这样代码会更简洁&#xff…

Kotlin 委托本质—委托模式

在Kotlin中,可以用过by关键字很好的实现委托,而Kotlin中委托其实就是委托模式的实现,而委托模式已经被证明是实现继承的好方式,通过by关键字将接口的实现委托给另一个对象。这样代码会更简洁,符合Kotlin的惯用写法。首先先介绍一下委托模式。

委托模式的核心是让一个对象将某些职责交给另一个对象处理,举个例子,你要维护一个列表,在某些情况下可能是查询、也有可能是批量添加或者删除,也有可能是排序,在Java中,你不知道具体的使用ArrayList还是LinkedList来实现,亦或是两个都实现一遍,这个时候就可以使用委托模式,使用委托对象,谁需要使用根据具体的情况选择ArrayList还是LinkedList。再比如Android中的Context,在Context类中就有很多未实现的方法,他只是实现了一个标准,而ContextWrapper持有了一个Context对象,具体的方法实现实在具体的对象,也就是Context的子类。
在这里插入图片描述
在这里插入图片描述

委托模式

委托模式拥有固定的模板,需要定义委托接口(行为),委托对象,委托者,委托着通过委托对象去实现某个行为(委托接口),我们在Java中实现一下委托模式:
首先定义一下委托行为,即接口也可以是抽象类,主要是用来指定规范

/*** 定义委托接口行为*/
public interface ParcelKeeper {void keep(String parcelId);
}
/*** 第一种实现方式*/
public class ParcelLocker implements ParcelKeeper {@Overridepublic void keep(String parcelId) {System.out.println(parcelId);}
}
/*** 第二种实现方式*/
public class ParcelStation implements ParcelKeeper {@Overridepublic void keep(String parcelId) {System.out.println(parcelId);}
}
/*** 委托者*/
public class Courier implements ParcelKeeper {// 关键点:持有委托对象private final ParcelKeeper keeper;public Courier(ParcelKeeper keeper) {this.keeper = keeper;}@Overridepublic void keep(String parcelId) {//使用委托对象的方法keeper.keep(parcelId);}public void save(String parcelId) {keep(parcelId);}
}

委托者不关心具体实现细节,由具体接口的实现类对象去处理相关的行为。

Kotlin的委托实现

我们按照委托模式的思想来通过Kotlin实现:首先还是定义一个接口

/*** 定义委托协议(需要做什么)*/
interface IBaseDoing {val name:Stringfun doSomething()fun printMessage(msg: String)
}
/*** 具体的实现类1*/
class ImplOne : IBaseDoing {override val name = "ImplOne"override fun doSomething() {println("ImplOne doSomething")}override fun printMessage(msg: String) {println("$name : $msg")}
}
/*** 具体的实现类2*/
class ImplTow : IBaseDoing {override val name = "ImplOne"override fun doSomething() {println("ImplTow doSomething")}override fun printMessage(msg: String) {println("$name : $msg")}
}

Kotlin中委托的语法是:class 类A(val obj: 接口B) : 接口B by obj { }

/*** 委托类,将自己的具体实现委托给IBaseDoing的实现类*/
class Custom(val obj: IBaseDoing) : IBaseDoing by obj {override val name: Stringget() = "Custom"override fun doSomething() {println("this is Custom class override: $name")}}
fun main() {val custom1 = Custom(obj = ImplOne())custom1.doSomething()val custom2 = Custom(obj = ImplTow())custom2.printMessage("hello kotlin")
}

测试结果:
在这里插入图片描述
在Kotlin中接口定义属性与方法,我们都可以在委托对象中直接重写属性的值和方法,值得注意的是,委托对象重写的属性,原有接口实现类中无法访问,例如上述中的类ImplTow中的name,其中printMessage方法是无法访问委托对象覆盖的属性。 同时我们也可以委托多个接口,有选择的重写其中的方法:

interface A {fun one()
}interface B {fun two()
}class DelegateAB(private val a: A, private val b: B) : A by a, B by b {override fun one() {}override fun two() {}}

Kotlin的属性委托

属性委托基础

Kotlin中不仅有接口委托,还有属性委托,属性委托的语法是:val/var <属性名>: <类型> by <表达式>,在 Kotlin 中,属性委托(Property Delegation)允许你将属性的 读(get) 和 写(set) 操作委托给另一个对象,从而复用或扩展属性的行为。这种机制通过 by 关键字实现,是 Kotlin 实现代码复用和逻辑解耦的重要特性。下面举个简单的例子实现属性委托:

class Cat {var name: String by MyDelegate("Kitty")
}class MyDelegate(private var initValue: String) {operator fun getValue(cat: Cat?, property: KProperty<*>): String {return initValue}operator fun setValue(cat: Cat?, property: KProperty<*>, value: String) {//这里不要直接赋值:cat?.name = value,会无限递归,变为java字节码反编译后可看调用原理initValue = value}
}
Kotlin 标准库中的内置属性委托
  • 延迟属性 Lazy properties

    val myLazyValue: String by lazy {println("Initializing...")"Hello, World!"}
    }
    val age: Int by lazy(LazyThreadSafetyMode.PUBLICATION) {23
    }
    

    值得一提的是,Kotlin的by lazy 又三种模式,SYNCHRONIZEDPUBLICATIONNONE,他们的区别在于是否是线程安全的,实现安全的方式,加锁或者CAS,可以看看 by lazy的源码实现。

  • observable:监听属性变化

    val observableProp: String by Delegates.observable("value1") { property: KProperty<*>, oldValue: String, newValue: String ->println("oldValue:$oldValue newValue:$newValue")
    }
    

    在这里插入图片描述

  • vetoable:条件拦截属性赋值,,符合lambda表达式的条件才会改变属性的值

    var con: Int by Delegates.vetoable(0) { _, oldValue, newVal ->newVal > oldValue
    }
    

    核心代码是ObservableProperty类中的setValue方法中进行了拦截在这里插入图片描述

  • Map 委托:将属性映射到 Map

    class User(private val map: Map<String, Any>) {private val name by mapprivate val age by mapprivate val isSuper: Boolean by mapoverride fun toString(): String {return "[name:$name,age:$age,isSuper:$isSuper]"}
    }fun main() {val user = User(mapOf("age" to 32, "isSuper" to false, "name" to "Tom"))println(user.toString())
    }
    

    通过map可以为属性赋值。

属性委托原理

其实属性委托的主要原理就是编译器为我们编译相关代码实现getValue和setValue方法的调用,官网文档也给出了解释:
在这里插入图片描述
Kotlin相关的委托基本上就介绍完毕了,学习这些主要是为后续的Android Compose打个基础,Compose库中使用了大量的Kotlin 高阶函数、Lambda表达式、委托等相关特性,因此这些基础就是更好的看懂Compose的源码,特此巩固下这块的知识。

http://www.dtcms.com/a/448795.html

相关文章:

  • 河南金城建设工程有限公司网站建行网站首页登录
  • 做网站 花园路国贸vps装网站管理系统
  • 广州做网络服装的网站建设网站策划书的撰写流程
  • 织梦做的网站好优化品牌设计工作室
  • 做怎么网站推广专做视频和ppt的网站
  • 空间设计师网站手机版百度入口
  • 网站多少页面合适全球搜索引擎市场份额
  • 国外哪个网站做c 挣钱推广普通话标语
  • 蓬莱做网站价格网站头部设计
  • 中国建设监理协会网站查询成绩wordpress 视频 去广告插件下载
  • 上海专业做网站推广的公司静态网页做的网站怎么发到网上
  • 别人的网站是怎么做的网站设置不能通过链接访问
  • 重庆站外推广网站网站设计评分标准
  • 网站闭站网站建设 系统维护
  • 东莞短视频推广是的无锡网站关键词优化
  • 网站开发公司赚钱么辽宁建设工程信息网、
  • 南皮县做网站价格三明网站优化
  • 网站推广策划方案的主要内容?outlook企业邮箱
  • 免费做手机网站建设汽车网站代码
  • 网站分享到朋友圈代码小红书推广平台有哪些
  • 象山网站优化公司建设网站开发方案
  • 做网站建设公司crm在线广东的一起做网站
  • 相册特效手机网站阿里云虚拟主机多网站
  • 电商网站活动推广门户网站建设工作管理办法
  • 免费网站推广渠道怎样给自己的店做网站
  • 音乐盒网站源码树莓派wordpress
  • 网站更换目录名如何做301跳转新人如何自学做网站
  • 邹城网站定制公司域名备案怎么弄
  • 建设学校网站中山市路桥建设有限公司网站
  • 做一个网站大概要多少钱做搬家服务网站问卷调查结果