Kotlin 接口

Kotlin 的接口可既包含抽象方法的声明也包含实现;接口法保存状态有属性必须声明为抽象或提供访问器实现

1、定义

使用关键字 interface 来定义接口

interface MyInterface {
    fun bar()
    fun foo() {
      // 可选的方法体
    }
}
2、 实现接口

一个类或者对象可以实现一个或多个接口

class Child : MyInterface {
    override fun bar() {
        // 方法体
    }
}
3、接口中的属性

在接口中定义属性,该属性要么是抽象的,要么提供访问器的实现,且不能有幕后字段(backing field)

interface MyInterface {
    val prop: Int // 抽象的

    val propertyWithImplementation: String
        get() = "foo"

    fun foo() {
        print(prop)
    }
}

class Child : MyInterface {
    override val prop: Int = 29
}
4、接口继承

一个接口可以从其他接口派生,意味着既能提供基类型成员的实现也能声明新的函数与属性;实现这样接口的类只需定义所缺少的实现

interface Named {
    val name: String
}

interface Person : Named {
    val firstName: String
    val lastName: String

    override val name: String get() = "$firstName $lastName"
}

data class Employee(
    // 不必实现“name”
    override val firstName: String,
    override val lastName: String,
    val position: Position
) : Person
5、覆盖冲突解决

实现多个接口时,可能会遇到同一方法继承多个实现的问题,需要实现从多个接口继承的所有方法,并指明继承类如何实现它们

interface A {
    fun foo() { print("A") }
    fun bar()                  // 在接口中没有方法体时默认为抽象
}

interface B {
    fun foo() { print("B") }
    fun bar() { print("bar") }
}

class C : A {
    override fun bar() { print("bar") } // 必须重写A的bar()
}

// 需要实现多个接口继承的所有方法 foo() bar()
class D : A, B {
    override fun foo() {
        super<A>.foo()
        super<B>.foo()
    }

    override fun bar() {
        super<B>.bar()
    }
}
6、函数式接口

一个抽象方法的接口 单一抽象方法接口,以有多个非抽象成员,但能有一个抽象成员

使用 fun 修饰符声明一个函数式接口

fun interface KRunnable {
   fun invoke()
}

 SAM 转换

对于函数式接口,可以通过 lambda表达式实现 SAM 转换,从而使代码更简洁、更有可读性

fun interface IntPredicate {
   fun accept(i: Int): Boolean
}
// 不使用 SAM 转换
// 创建一个类的实例
val isEven = object : IntPredicate {
   override fun accept(i: Int): Boolean {
       return i % 2 == 0
   }
}
// 利用 Kotlin 的 SAM 转换
// 通过 lambda 表达式创建一个实例
val isEven = IntPredicate { it % 2 == 0 }

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在Kotlin中,可以使用lambda表达式来简化接口回调的实现。通过lambda表达式,可以直接将函数作为参数传递给其他函数或方法。这样可以避免创建额外的接口实现类。例如,可以使用lambda表达式来简化setOnItemClickListener的实现。在SomeListAdapter类中,可以直接定义一个函数类型的变量mOnItemClickListener,并将其作为参数传递给onBindViewHolder方法。这样就可以在onBindViewHolder方法中直接调用mOnItemClickListener函数,而不需要使用setOnItemClickListener方法。\[1\] 另外,如果想要在Kotlin实现接口回调,可以使用接口类型变量和lambda表达式的组合。可以定义一个接口类型变量mListener,并使用setListener方法将lambda表达式作为参数传递给mListener。然后在work方法中,可以直接调用mListener的方法。这样就可以实现接口回调的功能。\[2\] 此外,如果想要在Kotlin实现点击事件的回调,可以使用匿名内部类的方式。可以通过setOnClickListener方法,传入一个匿名内部类对象,并在该对象中重写onClick方法。在onClick方法中,可以实现点击事件的逻辑。\[3\] #### 引用[.reference_title] - *1* [kotlin接口回调](https://blog.csdn.net/weixin_33716941/article/details/91874861)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Kotlin 高级函数实现回调详解](https://blog.csdn.net/weixin_42046829/article/details/105763041)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值