Kotlin嵌套类和内部类

嵌套类

类可以嵌套在其他类中,需要通过外部类才可以访问嵌套类的成员,外部类.嵌套类.嵌套类成员。嵌套类不能直接访问外部类的成员。

class Outer {
    private val bar: Int = 1
    class Nested {
        fun foo() = 2
    }
}

val demo = Outer.Nested().foo() // == 2

内部类

类可以标记为 inner 以便能够访问外部类的成员。内部类会带有一个对外部类的对象的引用。外部类访问内部类:外部类.内部类.内部类成员。如果内部类与外部类有同名变量,那么当内部类想要访问外部类的同名变量时,需要用到this。如果 this 没有限定符,它指的是最内层的包含它的作用域。要引用其他作用域中的 this,请使用标签限定符(this@label),其中 @label 是一个代指 this 来源的标签。

class Outer {
    private val bar: Int = 1

    inner class Inner {
        val bar: String = ""
        fun foo() = this@Outer.bar
    }
}

val demo = Outer().Inner().foo() // == 1

匿名内部类

使用对象表达式创建匿名内部类实例:

interface TestInterface {
    fun foo(pa: Int)
    fun foo0()
}

class TestClazz {
    fun bar(testInterface: TestInterface) {
        testInterface.foo(1)
        testInterface.foo0()
    }
}

class Test {
    var p1: Int = 1
    fun test(mm: Int) {
        val p2: Int = 1
        val testClazz: TestClazz = TestClazz()
        testClazz.bar(object : TestInterface {//匿名内部类
            override fun foo(pa: Int) {
                //匿名内部类可以访问局部变量和成员变量
                p1 = p2 + pa
            }

            override fun foo0() {
            }
        })
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kotlin中的嵌套(Nested Classes)和内部类(Inner Classes)是非常相似的概念,但有一些细微的区别。以下是对它们的一些基本介绍: 1. **嵌套(Nested Classes)**:在Kotlin中,嵌套是一种,它包含在另一个的内部。它可以是静态的(static)、非静态的(inner)或者局部的(local)。嵌套可以从任何访问它的外部访问字段、方法、构造器和嵌套。这允许一个的数据可以在嵌套中被更细粒度地访问和控制。 ```kotlin class OuterClass { class NestedClass { // code inside } } ``` 2. **内部类(Inner Classes)**:内部类是定义在另一个内部的。它可以直接访问外部的所有成员,包括字段、方法、构造器和嵌套内部类可以包含自己的构造函数,并且可以访问外部的私有成员。内部类可以嵌套在其他内部类中,形成一个复杂的层次结构。 ```kotlin class OuterClass { inner class InnerClass { // code inside } } ``` 总的来说,内部类在实现接口、继承某个或封装内部数据结构时特别有用。另一方面,嵌套提供了一种更灵活的方式来访问外部的数据和方法,即使外部在不同的包或模块中。 需要注意的是,尽管Kotlin中的嵌套内部类非常相似,但在某些情况下,使用嵌套的语法可能更清晰和直观。例如,使用嵌套可以更清楚地表示一个嵌套结构,而内部类则更适合实现接口或封装内部数据结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值