scala學習筆記

lazy
定義為lazy的變量在第一次應(yīng)用時才會求值
var a = 4, b = 2
lazy var c = a * b

Unit
相當于Java中的void

Nothing
函數(shù)拋出異常時返回Nothing

String
scala支持字符串插值
var name : String = "chenfeng"
var newstr : String = s"my name is ${name}"

3種函數(shù):
def hello1(name : String) : String = {
s"new String return : {name}" } def hello2(name : String) = { // 自動推斷返回值類型 s"new String return :{name}"
}
def hello3(x : Int, y : Int) = x + y // 只有一條語句可以省略代碼塊括號

3種for循環(huán)
val l = List("alice", "bob", "cathy")

for (
    s <- l
) println(s)                              

for {
    s <- l
    if (s.length > 3)
} println(s)

val result_for = for {
    s <- l
    s1 = s.toUpperCase()
    if (s1 != "")
} yield (s1)
println(result_for)

try and match
val result_try = try {
Integer.parseInt("dog")
} catch {
case _ => 0
} finally {
println("always be printed")
}
println(result_try)

val code = 3
val result_match = code match {
    case 1 => "one"
    case 2 => "two"
    case _ => "others"
}
println(result_match)

2種求值策略
call by value
call by name

函數(shù),高階函數(shù)苛骨,匿名函數(shù),遞歸函數(shù)
高階函數(shù):用函數(shù)作為形參或返回值的函數(shù)
def operate(f : (Int, Int) => Int) {
f(4, 4)
}
def greeting() = (name : String) => s"my name is ${name}"

匿名函數(shù)歧胁,又稱為函數(shù)常量镶骗、函數(shù)文字量桶现,格式為 (形參列表) => {函數(shù)體}
     var add() = (x : Int, y : Int) => x + y
     add(1, 2)
     
     def greeting() = (name : String) => s"my name is ${name}"
     greeting()("zhangsan")
     def greeting2(x : Int) = (name : String) => s"my name ${x} is ${name}"
     greeting(12)("olala")

遞歸函數(shù):在函數(shù)式編程中實現(xiàn)循環(huán)的一種技術(shù)
尾遞歸函數(shù):所有遞歸函數(shù)的調(diào)用都出現(xiàn)在函數(shù)的末尾,當編譯器檢測到是尾遞歸時卖词,覆蓋當前活動記錄而不是在棧中創(chuàng)建新的

柯里化
object test {

def main(args: Array[String]): Unit = {
    sum(x => x)(1)(5)
    sum(x => x * x)(1)(5)
}

def sum(f: Int => Int)(a: Int)(b: Int): Int = {

    @annotation.tailrec
    def loop(n: Int, acc: Int): Int = {
        if (n > b) {
            println(s"n=${n}, acc=${acc}, innerest")
            acc
        } else {
            println(s"n=${n}, acc=${acc}")
            loop(n + 1, acc + f(n))
        }
    }

    loop(a, 0)
}

}

List[T]
val l = List(1, 2, 3, 4)

連接元素
      ::巩那,從后向前連接
      val c = "x" :: "y" :: "z" :: Nil     // List[String] = List(x, y, z)
連接列表
      :::
      val d = l ::: c                            // List[Any] = List(1, 2, 3, 4, x, y, z)
獲取元素
      l.head
      l.tail
      l.isEmpty

      def walkthrough(list : List[Int]) : String= {
               if (list.isEmpty)
                    ""
               else
                    l.head.toString + " " + walkthrough(list.tail)
     }
      walkthrough(l)

高級函數(shù)
     toList
          "this is a string".toList        // List[Char] = List(t, h, i, s,  , i, s,  , a,  , s, t, r, i, n, g)
     filter
          "this is a string, 123".toList.filter(x => Character.isDigit(x))     // 取出數(shù)字 List[Int] = List(1, 2, 3)
     takeWhile
          "this is a string, 123".toList.takeWhile(x => x != s)                    // List[String] = List(t, h, i, s,  , i, s,  , a,  )

     map 映射,將列表中元素一一映射到新的值
          var a = "this is a string".toList
               a.map(x => x.toUpperCase)
               a.map(_.toUpperCase)
          var b = List(1, 2, 3, 4,  5)
               b.filter(x => x % 2 == 1)
               b.filter(_ % 2 == 1).map(_ + 10)
          var c = List(List(1, 2, 3), List(4, 5, 6))
               c.map(x => x.filter(x % 2 == 1))
               c.map(_.filter(_ % 2 == 1))
               c.flatMap(_.filter(_%2==1))          // 將多層list壓平成一層
     
     規(guī)約此蜈,從左向右
         reduceLeft
              a.reduceLeft((x, y) => x + y)
              a.reduceLeft(_+_) 
         foldLeft
              a.foldLeft(0)((x, y) => x + y)
              a.foldLeft(0)(_+_)

     Range
          1 to 10          // Range(1, 2, 3, ..., 10)
          1 to 10 by 2     // Range(1, 3, 5, 7, 9)
          1 until 10      // Range(1, 2, 3, ..., 9)
          (1 to 10).toList     // List[Int] = List(1, 2, 3, ..., 10)

      Stream:Stream is a lazy list
          val s = 1 #:: 2 #:: 3 #:: Steam.empty          // Stream(1, ?)
          val s = (1 until 1000000).toSteam             // Stream(1, ?)
          s.head     // 1
          s.tail        // Stream(2, ?)

      Map
          val p = Map(1 -> "David", 9 -> "Elwood")     // 創(chuàng)建
          p(1)                                                                // 獲取即横,String = David
          p.contains(1)                                                 // true
          p.keys     // Set(1, 9)
          p.values     // MapLike(David, Elwood)
          p + (8 -> "Archer")
          p ++ List(3 -> "afa", 4 -> "fage")
          p - 1
          p -- List(1, 9, 3)

      Tuple
          創(chuàng)建          
               (1, 2)
               1 -> 2
          var a = List(1, 2, 3)
          def sumSq(in : List[Int]) : (Int, Int, Int) = {
               in.foldLeft((0, 0, 0))(t, v) => (t._1 + 1, t._2 + v, t._3 + v * v))
          }
          sumSq(a)     // (3, 6, 14)

Scala快速排序
def QuickSort(nums : List[Int]) : List[Int] = { if (nums.length < 2) nums else QuickSort(nums.filter(_ < nums.head) ++ nums.filter(_ == nums.head) ++ qSort(nums.filter(_ > nums.head))

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市裆赵,隨后出現(xiàn)的幾起案子东囚,更是在濱河造成了極大的恐慌,老刑警劉巖战授,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件页藻,死亡現(xiàn)場離奇詭異,居然都是意外死亡植兰,警方通過查閱死者的電腦和手機份帐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來楣导,“玉大人废境,你說我怎么就攤上這事⊥卜保” “怎么了噩凹?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長毡咏。 經(jīng)常有香客問我驮宴,道長,這世上最難降的妖魔是什么呕缭? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任堵泽,我火速辦了婚禮,結(jié)果婚禮上臊旭,老公的妹妹穿的比我還像新娘落恼。我一直安慰自己,他們只是感情好离熏,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著戴涝,像睡著了一般滋戳。 火紅的嫁衣襯著肌膚如雪钻蔑。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天奸鸯,我揣著相機與錄音咪笑,去河邊找鬼。 笑死娄涩,一個胖子當著我的面吹牛窗怒,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蓄拣,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼扬虚,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了球恤?” 一聲冷哼從身側(cè)響起辜昵,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎咽斧,沒想到半個月后堪置,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡张惹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年舀锨,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宛逗。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡坎匿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出拧额,到底是詐尸還是另有隱情碑诉,我是刑警寧澤,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布侥锦,位于F島的核電站进栽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏恭垦。R本人自食惡果不足惜快毛,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望番挺。 院中可真熱鬧唠帝,春花似錦、人聲如沸玄柏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽粪摘。三九已至瀑晒,卻和暖如春绍坝,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背苔悦。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工轩褐, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人玖详。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓把介,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蟋座。 傳聞我的和親對象是個殘疾皇子拗踢,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容

  • lang 2.1.和Java的異同 2.1.1.語法 Java++:增加的語法 -》純OO;操作符重載蜈七;closu...
    時待吾閱讀 2,369評論 0 0
  • Scalable 編程語言特點(可伸縮的秒拔,既可以編寫小腳本,又可以寫服務(wù)端的大程序) 純正的面向?qū)ο笳Z言 函數(shù)式語...
    Sx_Ren閱讀 411評論 0 1
  • scala文檔 包含內(nèi)容 1基礎(chǔ) 2控制結(jié)構(gòu)和函數(shù) 3數(shù)組相關(guān)操作 4映射和元組 5類 6對象 7.包和引入(x)...
    zlcook閱讀 1,001評論 0 3
  • 22.13.main方法 Scala的main方法(類似java的static方法)必須定義在一個object內(nèi):...
    時待吾閱讀 760評論 0 0
  • FP 3.1.函數(shù) 函數(shù)的地位和一般的變量是同等的飒硅,可以作為函數(shù)的參數(shù)砂缩,可以作為返回值。傳入函數(shù)的任何輸入是只讀的...
    時待吾閱讀 1,113評論 0 2