参考:https://blog.csdn.net/weixin_38244174/article/details/105955345
package com.example.myapplication
//消息实体类,两个参数,一个是消息内容,一个是消息类型,消息类型为发出消息和接收消息两种。
class Msg(val content: String, val type: Int) {
companion object {
//将其定义成常量,定义常量的关键字为const,只有在单例类、companion object和顶层方法才能使用const关键字
const val TYPE_RECEIVED = 0
const val TYPE_SENT = 1
}
}
Kotlin之延迟初始化和密封类
1、对变量延迟初始化
很多全局变量不可能为空,但由于Kotlin语法特性,你不得不做许多非空判断保护,即使你很确定这玩意不可能为空。
class MainActivity : AppCompatActivity(), View.OnClickListener {
//因为初始化是在onCreate方法中进行,因此不得不将adapter赋值为null,同时将他的类型声明改成 MsgAdapter?
private var adapter: MsgAdapter? = null
private lateinit var adapter: MsgAdapter
override fun onCreate(savedInstanceState: Bundle?) {
...
//判断变量是否进行初始化,如果初始化,则不用重复对变量初始化,否则初始化
if(!::adapter.isInitialized) {
adapter = MsgAdapter(msgList)
}
}
override fun onClick(p0: View?) {
.....
adapter.notifyItemInserted(msgList.size - 1)
....
}
}
2、使用密封类优化代码
目的是解决为满足编译器要求编写无用条件分支的情况。优化前代码示例如下:
package com.example.myapplication
import java.lang.IllegalArgumentException
//定义一个接口,表示某个操作的执行结果
interface Result
//Success类用于表示成功时的结果
class Success(val msg: String) : Result
//Failure类用于表示失败时的结果
class Failure(val error: String) : Result
//接受一个Result参数,通过判断result类型返回不同的结果
fun getResultMsg(result: Result) = when (result) {
is Success -> result.msg
is Failure -> result.error
//else这块是完全执行不到的,但缺少的话代码将无法编译过。
//如果新增一个UnKnown类并实现了Result接口,用于表示未知的执行结果,但忘记写分支,将会抛出异常使程序崩溃
else -> throw IllegalArgumentException()
}
解决方法是使用Kotlin密封类,密封类的关键字是sealed class。优化后的代码如下所示:
package com.example.myapplication
import java.lang.IllegalArgumentException
//密封类
sealed class Result
//继承类需要后面加上一对括号
class Success(val msg: String) : Result()
class Failure(val error: String) : Result()
//class unkonwn(val time: String) : Result()
//else条件已经没有了?为什么呢?
//when传入密封类时,Kotlin会自动检查该密封类有哪些子类,并强制要求你对每一个都需要处理(若不处理,编译不会通过)。即使没有else,也不会出现遗漏分支
fun getResultMsg(result: Result) = when (result) {
is Success -> result.msg
is Failure -> result.error
}