• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            The Fourth Dimension Space

            枯葉北風寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

            Scala數組操作

            scala中的數組比java的數組強大很多   
                1、定長數組:長度不變的數組Array,如:聲明一個長度為10的整形數組,val arr = Array[Int](10);聲明并初始化一個字符串數組: val arrStr = Array(“wo”,”cha”,”yo”)。訪問數組方式:訪問arrStr第一個元素,arrStr(1)即可
                2、變長數組(即數組緩沖):java中有ArrayList和scala中的ArrayBuffer等效;但是ArrayBuffer更加強大,通過下面的事列來熟悉ArrayBuffer:
            import collection.mutable.ArrayBuffer
                val arrbuff1 = ArrayBuffer[Int]()
                val arrBuff2 = ArrayBuffer(1,3,4,-1,-4)
                arrbuff1 += 23    //用+=在尾端添加元素
                arrbuff1 += (2,3,4,32) //同時在尾端添加多個元素
                arrbuff1 ++= arrBuff2 //可以用 ++=操作符追加任何集合
                arrbuff1 ++= Array(2,43,88,66)
                arrbuff1.trimEnd(2) //移除最后的2個元素
                arrbuff1.remove(2)  //移除arr(2+1)個元素
                arrbuff1.remove(2,4) //從第三個元素開始移除4個元素
                val arr = arrbuff1.toArray //將數組緩沖轉換為Array
                val arrbuff2 = arr.toBuffer //將Array轉換為數組緩沖
                3、遍歷數組和數組緩沖:在java中數組和數組列表/向量上語法有些不同。scala則更加統一,通常情況,我們可以用相同的代碼處理這兩種數據結構,for(…) yield 循環創建一個類型和原集合類型相同的新集合。for循環中還可以帶守衛:在for中用if來實現。
                for(i <- 0 until arrbuff1.length) yield arrbuff1(i) * 2 //將得到ArrayBuffer(2,6,4,-2,-4)
                for(i <- 0 until (arrbuff1.length,2)) yield arrbuff1(i) * 2 //將得到ArrayBuffer(12,-4)
                for(elem <-0 arrbuff1) print(elem) //如果不需要使用下標,用這種方式最簡單了
                for(i <- arrbuff1 if arrbuff1 > 0) print i //打印出arrbuff1中為整數的值
                arrbuff1.filter( _ > 0).map{ 2 * _} //生成arrbuff1中的正數的兩倍的新集合
                arrbuff1.filter {_ > 0} map {2 * _} //另一種寫法
                4、常用算法:scala有很多便捷內建函數,如
                arrbuff1.sum //對arrbuff1元素求和
                Array("asd","sdf","ss").max //求最大元素
                arrbuff1.sorted(_ < _)  //將arrbuff1元素從小到大排序
                arrbuff1.sorted(_ > _)  //從大到小排序
                util.Sorting.quickSort(Array) //針對數組排序,單不能對數組緩沖排序
                val arr = Array(1,23,4,2,45)
                arr.mkString(",") //指定分割符
                arr.mkString("(",",",")") //指定前綴、分隔符、后綴
            更多函數參見Scaladoc
                5、多維數組:
            val matrix = Array.ofDim[Int](5,4) //三行四列的二維數組
            matrix(2)(3) //訪問第二行、第三個元素
                6、scala數組和java互操作:由于scala數組是用java數組實現的,所以可以在java和scala之間來回傳遞,引入scala.collectin.JavaConversion ,可以在代碼中使用scala緩沖,在調用java方法時,這些對象會被自動包裝成java列表。反過來講,引入scala.collection.asScalaBuffer時,當java方法返回java.util.List時,我們可以讓它轉換成一個Buffer

            轉自:http://www.kankanews.com/ICkengine/archives/128572.shtml

            posted on 2014-10-04 11:52 abilitytao 閱讀(32059) 評論(3)  編輯 收藏 引用

            評論

            # re: Scala數組操作 2015-05-06 09:05 hpf

            val b = ArrayBuffer(1,7,2,9)
            val bSorted = b.sorted(_ > _)
            我這樣寫怎么報錯  回復  更多評論   

            # re: Scala數組操作 2015-07-17 14:26 niuzi

            @hpf
            sorted 沒有參數,默認按照>進行排序,這是快學scala里面的一處錯誤,應該用sortedWith(_ > _)  回復  更多評論   

            # re: Scala數組操作 2015-07-28 16:50 wyz

            sortWith( _ > _ )  回復  更多評論   

            精品国产乱码久久久久久1区2区| 久久99精品免费一区二区| 香蕉久久久久久狠狠色| 亚洲αv久久久噜噜噜噜噜| 久久精品国产99国产精偷| 亚洲一区精品伊人久久伊人| 99精品国产综合久久久久五月天| 久久91精品国产91久久小草| 人妻系列无码专区久久五月天| 久久婷婷五月综合色高清| 久久国产免费直播| 97久久精品人妻人人搡人人玩| 欧美精品丝袜久久久中文字幕 | 久久精品一区二区三区AV| 国产韩国精品一区二区三区久久| 久久久无码精品午夜| 久久99国产精品二区不卡| 亚洲国产精品一区二区久久hs| 久久99精品久久久久久不卡| 精品国产乱码久久久久久1区2区| 国产精品久久久久久久久久影院| 99久久国产亚洲高清观看2024| 欧美牲交A欧牲交aⅴ久久 | 无码人妻久久一区二区三区免费丨 | 国产91久久综合| 人妻无码中文久久久久专区| 久久笫一福利免费导航| 久久久久亚洲AV综合波多野结衣| 色综合久久精品中文字幕首页| 久久棈精品久久久久久噜噜| 久久99久国产麻精品66| 精品国产99久久久久久麻豆 | 97久久精品午夜一区二区| 欧美一区二区三区久久综合 | 亚洲国产成人久久精品动漫| 国产午夜福利精品久久2021| 久久青青草原精品国产| 国产韩国精品一区二区三区久久| 国产精品99久久久久久人| 久久久久综合网久久| 精品久久久久国产免费|