一. 操作符

  1. 自定义操作符

  2. 操作付默认左结合调用.除了以:结尾的操作符是右结合调用

    object OperaterTest extends App{
    val a: myInt = new myInt(1)
    val b: myInt = new myInt(2)
    val c: myInt = new myInt(3) println(a +++ b)
    println((c---:b---:a).value) //:结尾的操作符右结合,相当于(a.---:(b)).---:(c) = 1-2-3 } class myInt(val value:Int){
    def +++(a:myInt):Int = { // 定义操作符 +++
    a.value + value // 要使a.value能够访问,主构造器的字段要生命成val.使getter,setter方法为public
    } // 操作符默认左结合,除了以:结尾的操作符使o结合的右.比如::
    def ---:(a:myInt):myInt = {
    new myInt(this.value - a.value)
    }
    }

二.apply,update,ubapply去名调用

  1. apply(param)方法

    (1)apply对象通常声明在半生对象中,用来构造对象

    (2)cala把apply()方法的调用简化成了(param)

  2. update(param)方法

    update()方法的调用,简化成了(param)=

    object Test extends App{
    val scores = new mutable.HashMap[String,Int]
    scores("Bob") = 100 // update
    println(scores("Bob")) // apply
    }
  3. unapply方法

    (1)当用未初始化的变量放在一个类()里,和等式右侧的对象进行匹配时,则这些未初始化的变量调用该类的unapply方法进行初始化

    (2)unapply()方法返回的结果使Option[元祖]类型的,要么是None,要么是Some[T]

    object CaseClassTest extends App{
    val Name(first,scend,third) = "haha hehe lala"; // first,second,third必须是未声明的变量
    println(first)
    println(scend)
    println(third)
    } object Name{
    def unapply(input:String) :Option[(String,String,String)] = { //元祖:不同类型的值的集合
    if(input.indexOf(" ") == -1)
    None
    else
    Some(input.split(" ")(0),input.split(" ")(1),input.split(" ")(2))
    }
    }
  4. unapplySeq方法

    (1)unapply用来提取固定个数的变量,来给未知变量赋值.若要提取出不定长度的变量,用unapplySeq方法

    (2)unapplySeq与unapply不能同事存在,否则模式匹配时,只会调用unapply进行匹配

    object CaseClassTest extends App{
    val Name(first,scend,third) = "haha hehe lala"; // first,second,third必须是未声明的变量
    println(first)
    println(scend)
    println(third) val str = "asd sdf gh sdf"
    str match {
    case Name(a,b,c) => println("3 param:"+a+","+b+","+c)
    case Name(a,b,c,d) => println("4 param:"+a+","+b+","+c+","+d)
    }
    } object Name{ def unapplySeq(input:String):Option[Seq[String]] ={
    if(input.indexOf(" ") == -1)
    None
    else
    Some(input.split(" "))
    }
    }

三. Case Class

  1. 什么事样例类:经过scala编译器优化后,被更好的用于模式匹配规则的类

    (1)Case class的每个参数默认以val(不变形式)存在,除非显式的声明为var

    (2)自动产生伴生对象,、且半生对象中自动产生appay方法来构建对象

    (3)半生对象自动产生unapply方法,提取主构造器的参数进行模式匹配

    (4)自动产生copy方法,来构建一个与现有值相同的新对象

    (5)class中自动产生hashcode,toString,equals方法

    object CaseClassTest extends App{
    val currency:Money = RMB(12.3,"yuan")
    //多态下,子类的模式匹配
    currency match {
    case Dollar(x:Double) => println("dollar:"+x)
    case RMB(x:Double,y:String) => println("rmb:"+x+y) //rmb:12.3yuan
    } val currency2 = RMB(23.4,"yuan")
    println(currency2.copy(value=12.1)) //RMB(12.1,yuan) =>自动产生的toString } abstract class Money
    case class Dollar(value:Double) extends Money
    case class RMB(value:Double,danwei:String) extends Money
  2. 匹配循环嵌套的样例类

    (1)循环嵌套的样例类:一个case class的对象中,包含另一个case class的对象实例

    (2)因为对象存在循环嵌套,则需要使用递归处理对象,切该对象要有别名,用于递归处理。name @ pattern

    object CaseClassTest extends App{
    val bundle:Item = Bundle("Father's day special",20.0, // 这个对象包含2个Item,1个是artice,另一个是包含两个artice的Bundle
    Article("scala for impatient",39.3),
    Bundle("other lanugage",10.0,Article("thinking in java",79.5),Article("c++ progeamme",65.4))) def price(it:Item):Double= it match {
    case Article(_,price) => price
    case Bundle(_,disc,items @ _*) => items.map(price(_)).sum - disc
    } println(price(bundle))
    } abstract class Item
    case class Article(description:String,price:Double) extends Item
    case class Bundle(description:String,discount:Double,iterms:Item*) extends Item
  3. case class的密封

    (1)当case class的超类使用关键字sealed修饰,则编译器会校验对该超类对象的模式匹配规则中,是否列出了全部可能的子case类

    (2)且该超类的子类只能出现在超类的文件中,形成封闭,而不能出现在其他文件中

scala高级内容(一) Case Class的更多相关文章

  1. scala高级内容(二) - Implicit

    一. Implicit关键字 隐士转换 (1)隐士转换函数:用implicit修饰的,只有一个参数的函数.他会被自动执行,来把一个值转换成另一个 class RichFile(val f:File){ ...

  2. SQL Server高级内容之case语法函数

    1.Case函数的用法  (1)使用类似:switch-case与if-else if. (2)语法: case [字段] when 表达式 then 显示数据 when 表达式 then 显示数据 ...

  3. Scala进阶之路-Scala高级语法之隐式(implicit)详解

    Scala进阶之路-Scala高级语法之隐式(implicit)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我们调用别人的框架,发现少了一些方法,需要添加,但是让别人为你一 ...

  4. Lucene的查询及高级内容

    Lucene查询 基本查询: @Test public void baseQuery() throws Exception { //1. 创建查询的核心对象 FSDirectory d = FSDir ...

  5. 02.Scala高级特性:第6节 高阶函数;第7节 隐式转换和隐式参数

    Scala高级特性 1.    课程目标 1.1.   目标一:深入理解高阶函数 1.2.   目标二:深入理解隐式转换 2.    高阶函数 2.1.   概念 Scala混合了面向对象和函数式的特 ...

  6. scala 高级编程

    一.函数式编程 Scala中的函数可以独立存在, 不需要依赖任 何类和对象 def  放在类中就是方法:放在外边就是函数 1.将函数赋值给变量 Scala中的函数是一等公民, 可以独立定义, 独立存在 ...

  7. scala语言中的case关键字在spark中的一个奇特使用

    package com.spark.demo import com.spark.demo.util.SparkUtil import org.apache.spark.rdd.RDD import s ...

  8. Scala高级语法

    一.隐式 implicit分类: (1)隐式参数 (2)隐式转换类型 (3)隐式类 特点:让代码变得更加灵活 (一)隐式参数 1.ImplicitTest object ImplicitTest { ...

  9. scala学习手记40 - case表达式里的模式变量和常量

    再来看一下之前的一段代码: def process(input: Any) { input match { case (a: Int, b: Int) => println("Proc ...

随机推荐

  1. keil uvision看厌了么?试试Sublime Text吧!

    之前用 Sublime Text(以下简称 ST )配置了 C/C++ 开发环境,感觉相当不错,作为编辑器的 ST,编辑代码的功能当然是相当棒的,美中不足的是目前只能编译单个文件,但是用来做些小练习也 ...

  2. CSS基础知识点(一)

    CSS(Cascading Style Sheets)全称为:层叠样式表. 1.HTML元素类型 (1) 内联元素(inline):可以理解为“文本模式”,即从左到右顺序显示,不单独换行.常用的内联元 ...

  3. HDU 4597 记忆化搜索

    ² 博弈取牌—记忆化搜索 题目描述: 有两副带有数字的牌,(数字>0)两人轮流取,取中了某张牌,自己的分数就加上牌上的数字,但只能从两端取,每人都会用最优的策略使得自己的分数最高.问A先取,他能 ...

  4. 关于Toad连接DB2的sqlstate=08001错误

    新装的centos6.3+db29.7,数据库导入完了的之后用Toad连接访问之的时候出错了. DB2 Database Error: ERROR [08001] [IBM] SQL30081N A ...

  5. PHP避免刷新页面重复提交

    PHP避免刷新页面重复提交 2013-07-09 15:27 匿名 | 浏览 3567 次 编程语言 情景:从html提交数据到x.php 在x.php中$_POST数据写库并且显示,当x.php刷新 ...

  6. URAL 2030 Awesome Backup System

    Awesome Backup System Time limit: 2.0 secondMemory limit: 64 MB It is known that all people can be d ...

  7. POJ-1741 Tree (树上点分治)

    题目大意:一棵带边权无根树,边权代表距离,求距离小于等于k的点对儿数. 题目分析:这两个点之间的路径只有两种可能,要么经过根节点,要么在一棵子树内.定义depth(i)表示点 i 到根节点的距离,be ...

  8. Mac上因磁盘格式导致gulp无限刷新问题

    今天遇到个超奇葩的问题,使用gulp.watch监控文件变化,但是并没有修改文件,却一直执行change,导致浏览器无限刷新 调试了10小时,代码各种删改,一直不得其解.切换到Windows运行,又正 ...

  9. java的nio之:unix内核的五种I/O通信模型

    一:根据unix的网络编程对I/O模型的分类,UNIX提供了5种I/O模型===>阻塞I/O模型:最常用的I/O模型.所有文件操作都是阻塞的.我们以套接字接口为例讲解此模型:在进程空间中调用re ...

  10. sed详解

    1. Sed简介 sed 是一种在线编辑器,它一次处理一行内容.处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后 ...