==> Scala 中的數(shù)據(jù)集合:Map、列表、序列、集
在山城等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計(jì),營銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè)公司,山城網(wǎng)站建設(shè)費(fèi)用合理。==> 集合有兩種:可變集合,不可變集合
---> 可變集合可以對集合進(jìn)行修改操作
---> 不可變集合集合從不改變,因此可以安全的共享其引用
==> Map
---> 可變
val employeeInfo = scala.collection.mutable.Map("name"->"Tom", "age"->25, "gender"->"man")
---> 不可變
val employeeInfo = scala.collection.immutable.Map("name"->"Tom", "age"->25, "gender"->"man")
---> 操作
val employeeInfo = scala.collection.mutable.Map("name"->"Tom", "age"->25, "gender"->"man") // 獲取集合中的值 employeeInfo("name") // 若 Key 不存在,會(huì)拋出 Exception,因此,需要進(jìn)行判斷 if (employeeInfo.contains("girlfriend")){ employeeInfo("girlfriend") }else{ -1 } // 可以簡寫成 employeeInfo.getOrElse("girlfriend", -1) // 可以修改可變集合中的值 employeeInfo("age") = 28 // 也可以添加字?jǐn)?shù) employeeInfo += "girlfriend" -> "如花"
==> 列表
---> 可變
import scala.collection.mutable // 定義一個(gè)可變列表 val testList = mutable.LinkedList(1,2,3,4,5) // 對列表進(jìn)行操作: 將列表中的每個(gè)值 乘以 2 // 首先定義一個(gè)指針指向列表的開始 var cur = testList // 使用循環(huán)操作列表,Nil 相當(dāng)于 null while(cur != Nil){ // elem 相當(dāng)于一個(gè)變量,將循環(huán)取出的值賦給此變量,乘以2 cur.elem = cur.elem * 2 // 將指針指向下一個(gè)元素 cur = cur.next } println(testList)
---> 不可變
定義一個(gè)不可變列表 val testList = List(1,2,3,4) 定義一個(gè)空列表 val testList1:List[Nothing] = List() 定義一個(gè)二維列表 val testList2:List[List[Int]] = List(List(1,2,3), List(4,5,6)) 判斷列表是否為空 testList.isEmpty 查看列表第一個(gè)元素 testList.head tail 返回除去第一個(gè)元素后其余的所有元素 testList.tail
==> 序列
---> Range(2,5)
---> (2 to 4)
---> (2 until 5)
==> 集 (set) 不重復(fù)元素的集合,不保留元素插入的順序,默認(rèn)以 Hash 集實(shí)現(xiàn)
---> 創(chuàng)建集以及操作
// 創(chuàng)建一個(gè)集 var testSet = Set(1,3,5,9,8) // 向集中添加元素 testSet += "hello" // 判斷元素是否存在 testSet contains(3) // 判斷一個(gè)集是否是它的子集 Set(1,3) subsetOf(testSet)
---> 集的運(yùn)算(并集、交集、差集)
var testset1 = Set(1,2,3,4,5,6) var testset2 = Set(4,5,6,7,8,9) // 并集 testset1 union testset2 res8: scala.collection.immutable.Set[Int] = Set(5, 1, 6, 9, 2, 7, 3, 8, 4) // 交集 testset1 intersect testset2 res10: scala.collection.immutable.Set[Int] = Set(5, 6, 4) // 差集 testset1 diff testset2 res11: scala.collection.immutable.Set[Int] = Set(1, 2, 3)
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。