Scala中Map和Tuple

    1. 默認(rèn)情況下Map構(gòu)造的是不可變的集合涨冀,里面的內(nèi)容不可修改船惨,一旦修改就變成新的Map,原有的Map內(nèi)容保持不變擂错;
    1. Map的實(shí)例是調(diào)用工廠方法模式apply來(lái)構(gòu)造Map實(shí)例味滞,而需要主要的是Map是接口,在apply中使用了具體的實(shí)現(xiàn)
    // 調(diào)用工廠方法模式apply來(lái)構(gòu)造Map實(shí)例钮呀,而需要主要的是Map是接口剑鞍,在apply中使用了具體的實(shí)現(xiàn)
    val bigDatas = Map("Spark" -> 5, "Hadoop" -> 11)
    1. 如果想直接new出Map實(shí)例,則需要使用HashMap等具體的Map子類爽醋;
    1. 查詢一個(gè)Map中的值一定是采用getOrElse的語(yǔ)法蚁署,一方面是在key不存在的情況下不報(bào)告異常,另外還有一個(gè)作用就是提供默認(rèn)值蚂四;而關(guān)于默認(rèn)值的提供在實(shí)際開發(fā)中至關(guān)重要光戈,在Spark中很多默認(rèn)的配置都是通過getOrElse的方式來(lái)實(shí)現(xiàn)的哪痰;
    val programingLanguage = scala.collection.mutable.Map("Scala" -> 13, "Java" -> 23)
    programingLanguage("Scala") = 10
    for((name, age) <- programingLanguage) println(name + " : " + age)
    println(programingLanguage.getOrElse("Python", "123"))
    1. 使用SortedMap可以得到排序的Map集合;
    val persons = scala.collection.mutable.SortedMap(("yaj", 28), ("yrz", 4),("xh", 30))
    for((age, name) <- persons) println(name + " : " + age)
    1. LinkedHashMap可以記住插入數(shù)據(jù)的順序久妆,這在實(shí)際開發(fā)中非常有用晌杰;
    val personsInformation2 = new scala.collection.mutable.LinkedHashMap[String, Int]
    personsInformation2 += ("Scala" -> 13, "Java" -> 23, "Python" -> 10)
    for((name, age) <- personsInformation2) println(name + " : " + age)
    val personsInformation = new scala.collection.mutable.HashMap[String, Int]
    personsInformation += ("Scala" -> 13, "Java" -> 23)
    personsInformation -= ("Scala")
    for((name, age) <- personsInformation) println(name + " : " + age)
    for(key <- personsInformation.keySet) println(key)
    for(value <- personsInformation.values) println(value)
    println(personsInformation.keySet)
    println(personsInformation.values)
    1. Tuple中可以有很多不同類型的數(shù)據(jù),例如("yaj", "Spark", "30", "I LOVE SCALA!!!")
    1. 在企業(yè)級(jí)實(shí)際開發(fā)大數(shù)據(jù)的時(shí)候一定會(huì)反復(fù)的使用Tuple來(lái)表達(dá)數(shù)據(jù)結(jié)構(gòu)镇饺,以及使用Tuple來(lái)處理業(yè)務(wù)邏輯
    val info = ("yaj", "Spark", "30", "I LOVE SCALA!!!")
    println(info._4)
    1. Tuple的另外一個(gè)非常重要的使用是作為函數(shù)的返回值乎莉,在Tuple中返回若干個(gè)值,以SparkContext源碼為例來(lái)說(shuō)明

完整的實(shí)例如下:

    object HelloMapTuple {
  def main(args: Array[String]): Unit = {

    // 調(diào)用工廠方法模式apply來(lái)構(gòu)造Map實(shí)例奸笤,而需要主要的是Map是接口惋啃,在apply中使用了具體的實(shí)現(xiàn)
    val bigDatas = Map("Spark" -> 5, "Hadoop" -> 11)


    val programingLanguage = scala.collection.mutable.Map("Scala" -> 13, "Java" -> 23)
    programingLanguage("Scala") = 10
    for((name, age) <- programingLanguage) println(name + " : " + age)
    println(programingLanguage.getOrElse("Python", "123"))

    val personsInformation = new scala.collection.mutable.HashMap[String, Int]
    personsInformation += ("Scala" -> 13, "Java" -> 23)
    personsInformation -= ("Scala")
    for((name, age) <- personsInformation) println(name + " : " + age)
    for(key <- personsInformation.keySet) println(key)
    for(value <- personsInformation.values) println(value)
    println(personsInformation.keySet)
    println(personsInformation.values)

    val result = for((name, age) <- personsInformation) yield (age, name)
    for((age, name) <- result) println(name + " : " + age)

    val persons = scala.collection.mutable.SortedMap(("yaj", 28), ("yrz", 4),("xh", 30))
    for((age, name) <- persons) println(name + " : " + age)

    val personsInformation2 = new scala.collection.mutable.LinkedHashMap[String, Int]
    personsInformation2 += ("Scala" -> 13, "Java" -> 23, "Python" -> 10)
    for((name, age) <- personsInformation2) println(name + " : " + age)

    val info = ("yaj", "Spark", "30", "I LOVE SCALA!!!")
    println(info._4)

  }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市监右,隨后出現(xiàn)的幾起案子边灭,更是在濱河造成了極大的恐慌,老刑警劉巖健盒,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件绒瘦,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡扣癣,警方通過查閱死者的電腦和手機(jī)惰帽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)父虑,“玉大人该酗,你說(shuō)我怎么就攤上這事∈亢浚” “怎么了呜魄?”我有些...
    開封第一講書人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)莱衩。 經(jīng)常有香客問我爵嗅,道長(zhǎng),這世上最難降的妖魔是什么笨蚁? 我笑而不...
    開封第一講書人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任睹晒,我火速辦了婚禮,結(jié)果婚禮上赚窃,老公的妹妹穿的比我還像新娘册招。我一直安慰自己,他們只是感情好勒极,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開白布是掰。 她就那樣靜靜地躺著,像睡著了一般辱匿。 火紅的嫁衣襯著肌膚如雪键痛。 梳的紋絲不亂的頭發(fā)上炫彩,一...
    開封第一講書人閱讀 51,578評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音絮短,去河邊找鬼江兢。 笑死,一個(gè)胖子當(dāng)著我的面吹牛丁频,可吹牛的內(nèi)容都是我干的杉允。 我是一名探鬼主播,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼席里,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼叔磷!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起奖磁,我...
    開封第一講書人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤改基,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后咖为,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體秕狰,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年躁染,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鸣哀。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡吞彤,死狀恐怖诺舔,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情备畦,我是刑警寧澤,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布许昨,位于F島的核電站懂盐,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏糕档。R本人自食惡果不足惜莉恼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望速那。 院中可真熱鬧俐银,春花似錦、人聲如沸端仰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)荔烧。三九已至吱七,卻和暖如春汽久,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背踊餐。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工景醇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吝岭。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓三痰,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親窜管。 傳聞我的和親對(duì)象是個(gè)殘疾皇子散劫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

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