scala中模式匹配的应用

Scala 复制代码
package test34

object test6 {

    case class Person(name:String)
    case class Student(name:String, className:String)

    // match case 能根据 类名和属性的信息,匹配到对应的类
    // 注意:
    // 1 匹配的时候,case class的属性个数要对上
    // 2 属性名不需要一一对应
    def main(args: Array[String]): Unit = {
        val p1 = Persom("小花")
        val s1 = Student("小明","2(3)班")

        val a:Any = p1
        a match {
            case Person(nm) => println("普通人类", nm)
            case Student(name.className) => println(className,"的学生", name)
            case _ => println("其他")
        }
    }
}
Scala 复制代码
object test7 {
    // 需求:现在有一个数组Array(1,2,3,4),我希望能定义三个变量,它们的值分别是数组中的第1,2,3个元素的值
    def main(args: Array[String]): Unit = {
        val arr = Array(1,2,3,4,5)
    // 第一个元素的值: arr(0)
    // println(arr(0))
    // var x = arr(0)
    // var y = arr(1)
    // var z = arr(2)
    // println(x,y,z)
    // 有一个更简单的方式

    // 模式匹配
    var Array(x,y,z. _*) = arr
    println(x)
    println(y)
    println(z) 
    }
}
相关推荐
canonical_entropy1 天前
AI时代,我们还需要低代码吗?—— 一场关于模型、演化与软件未来的深度问答
后端·低代码·aigc
颜如玉1 天前
HikariCP:Dead code elimination优化
后端·性能优化·源码
考虑考虑1 天前
Jpa使用union all
java·spring boot·后端
bobz9651 天前
virtio vs vfio
后端
Rexi1 天前
“Controller→Service→DAO”三层架构
后端
bobz9651 天前
计算虚拟化的设计
后端
深圳蔓延科技1 天前
Kafka的高性能之路
后端·kafka
Barcke1 天前
深入浅出 Spring WebFlux:从核心原理到深度实战
后端
JuiceFS1 天前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
大鸡腿同学1 天前
Think with a farmer's mindset
后端