大資料Scala系列之樣例類_Option_偏函式

好程式設計師IT發表於2019-10-17

  在Scala中Option型別樣例類用來表示可能存在或也可能不存在的值(Option的子類有Some和None)。Some包裝了某個值,None表示沒有值。

object OptionDemo {
   def  main(args: Array[String]) {
     val map = Map( "a" -> 1, "b" -> 2)
     val v = map. get( "b") match {
       case Some(i) => i
       case None => 0
    }
     println(v)
     //更好的方式
     val v1 = map. getOrElse( "c", 0)
     println(v1)
  }
}

偏函式

被包在花括號內沒有match的一組case語句是一個偏函式,它是PartialFunction[A, B]的一個例項,A代表引數型別,B代表返回型別,常用作輸入模式匹配

object PartialFunctionDemo {
   def f: PartialFunction[String, Int] = {
     case  "one" => 1
     case  "two" => 2
    // case _ => -1
  }

   def  main(args: Array[String]) {
     //呼叫f.apply("one")
     println( f( "one"))
     println(f. isDefinedAt( "three"))
     //丟擲MatchError
     println( f( "three"))
  }
} String INTERPOLATION(字串插值)(備選)

用途:處理字串  型別:

  • s:字串插值
  • f:插值並格式化輸出
  • raw:對字串不作任何變換的輸出

Scala 2.10.0之後,引入一種新的建立字串的機制,即 String Interpolation. 它允許使用者直接在字串中嵌入變數的引用。

val name= "James"
println(s "Hello,$name") // Hello, James

字串插值的位置也可以放表示式,如下:

println(s "1 + 1 = ${1 + 1}") // 1 + 1 = 2

插值f 可以對字串進行格式化,類似printf:

val height = 1.9d
val name = "James"
println(f "$name%s is $height%2.2f meters tall")   // James is 1.90 meters tall

raw類似於s,但是raw對字串內容不作任何的轉換:

scala> s "a \n b"
res0: String =
a
b

scala> raw "a \n b"
res1: String = a\nb


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69913892/viewspace-2660320/,如需轉載,請註明出處,否則將追究法律責任。

相關文章