Kotlin学习-持续更新版

1. Kotlin Noting

  • 首先看Noting这个类
public class Nothing private constructor()
  • 非常简单,通过将构造函数设置为private,使得其成为一个无法创建实例对象的一个类,那么,这个不可能有实例对象的类有什么用呢。因为Nothing有一个特性,是所有类型的字类型,因此有以下作用:
  1. 适用于确定不会返回的函数:比如抛异常的工具函数,或者无限循环的函数。通过返回Noting,提示函数调用者,这是一个确定进入后就无法返回的函数。
// 本函数确定不可能返回,通过Nothing类提醒调用者
fun nothing(): Nothing {
	// 抛异常,可以忽略返回值
	throw RuntimeException("Nothing")
}
// It returns Nothing, indicating that it never returns normally and always throws an exception instead.
fun throwOnNameNull(): Nothing {
	throw NullPointerException("Name cann't be null!")
}
  1. 作为范型类型的实例化参数,比如List<Nothing>,由于Nothing无任何实例,因此这个List永远为空,使用这一个对象作为各种类型的List的初始化/临时填充,可以达到节约内存的作用
val emptyList: List<Nothin> = listOf()
// 需要var类型,不然真的就永久空白列表了
var apples: List<Apple> = emptyList
var pears: List<Pear> = emptyList
// ... 

2 Kotlin的范型和委托

2.1范型的使用
  • 例子1:通过范型和扩展函数,使用类似链式的方法,简化对象生成的赋值操作。

通过build扩展函数提供类似 Builder 模式的链式调用语法,让我们在创建对象时可以更简洁明了。build扩展函数将传入的 block 参数,应用于当前对象 this,也就是将 this 作为函数类型参数的接收者对象,并执行 block 中的代码。然后将对象 this 返回,以便我们可以进行链式调用。

fun <T> T.build(block: T.() -> Unit): T {
	// 执行传入的代码块
    block()
    // 执行完代码块后将自身返回
    return this
}

data class Person(var name: String = "", var age: Int = 0)

fun useBuild() {
	// 扩展函数+范型,实现对任意对象创建的简化操作。
	// 是不是很熟悉,没错,Kotlin的apply扩展函数就是这么实现的。
    val person = Person().build {
        name = "Mark"
        age = 18
    }
    println(person)
}

// 
@kotlin.internal.InlineOnly
public inline fun <T> T.apply(block: T.() -> Unit): T {
    contract {
        callsInPlace(block, InvocationKind.EXACTLY_ONCE)
    }
    block()
    return this
}

fun main() {
    useBuild()
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值