Step into Kotlin - 16 - Data 类与 When 表达式
来源:互联网 发布:管家婆软件打不开 编辑:程序博客网 时间:2024/06/05 22:39
目录
- Data Class 与 When
- Data Class
- 特点
- 创建 Data 类
- 使用 Data 类
- When
- 特点
- When 中的表达式
- 匹配值和范围
- 匹配类型
- 匹配参数
- Data Class
- Data Class 与 When
摘要
Data 类的声明和使用,When 的匹配
Data Class 与 When
Data Class
特点
- Data 类是使用关键字
data
声明的类 - Data 类默认基于构造方法实现了
toString()
,componentN()
,copy()
,equals()
和hashCode()
方法,不在构造方法中定义的属性不会产生在toString()
结果中。 - Data 类可以直接使用
==
进行比较,同样不在构造方法中定义的属性不会用在比较上 - Data 类只表示数据,不能拥有行为
创建 Data 类
data class Customer(var name: String, var email: String)
使用 Data 类
创建对象
val peter = Customer("Peter", "peter@example.com")
复制对象
val peter2 = peter.copy()val peter3 = peter.copy(name = "")
ComponentN
val (name, email) = peterprintln("name=$name,email=$email")
When
特点
- When 类似
switch
但是功能更加强大,且不需要break
语句。 - 模式匹配可以匹配值,类型
When 中的表达式
When 中可以使用的表达式类型
- 类名,用于进行类型匹配
- 范围,用于匹配范围
- 函数,用于匹配参数
- else,匹配其它情况
匹配值和范围
val y = when (x) { 1 -> 2 3 -> 4 3, 10 -> 30 in 10..20 -> 20 !in 20..30 -> 40 else -> 0 }
匹配类型
val x = 10when (x) { is Int -> println("long") else -> println("else")}
匹配参数
private fun add(x: Int): Int { return x + 1}val x = 10when (x) { add(x) -> println("x=" + x) else -> println("else")}
0 0
- Step into Kotlin - 16 - Data 类与 When 表达式
- Step into Kotlin - 03 - 变量,常量与表达式
- Step into Kotlin - 11 - 类
- Step into Kotlin - 19 - 正则表达式
- Step into Kotlin - 12 - Object 与枚举
- Step into Kotlin - 18 - Extension 与 this
- Step into Kotlin - 23 - 与 Java 交互
- Step into Kotlin
- Step into Kotlin - 01 - 入门
- Step into Kotlin - 02 - 数据类型
- Step into Kotlin - 04 - 函数
- Step into Kotlin - 06 - 异常
- Step into Kotlin - 08 - 数组
- Step into Kotlin - 09 - 集合
- Step into Kotlin - 13 - 包
- Step into Kotlin - 14 - 继承
- Step into Kotlin - 15 - 注解
- Step into Kotlin - 17 - 泛型
- 设计模式之-----策略模式
- 公云等相关应用怎样用
- eclipse maven plugin 插件 安装 和 配置
- Java内存溢出和内存泄露
- hadoop2提交到Yarn: Mapreduce执行过程分析
- Step into Kotlin - 16 - Data 类与 When 表达式
- Android性能优化
- PHP程序员?
- Ant build.xml
- Java学生成绩管理系统
- thinkphp复合WHERE查询的写法
- UNITY3D初学笔记
- AVFoundation视频播放、存储原理分析与使用
- Oracle ltrim() rtrim() 函数详细用法