• <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( _ > _ )  回復  更多評論   

            久久婷婷五月综合色奶水99啪| 久久精品国产精品国产精品污| 欧美日韩中文字幕久久久不卡| 狠狠色婷婷久久综合频道日韩 | 成人亚洲欧美久久久久| 久久久艹| 2021久久国自产拍精品| 亚洲人AV永久一区二区三区久久| 久久精品国产亚洲AV大全| 久久久精品视频免费观看 | 国产激情久久久久影院老熟女| 亚洲七七久久精品中文国产| 国产精品久久久久天天影视| 久久久精品国产免大香伊 | 久久精品成人免费观看97| 伊人久久综合成人网| 久久精品国产72国产精福利| 粉嫩小泬无遮挡久久久久久| 无码8090精品久久一区 | 精品久久久久久中文字幕大豆网| 91久久精品国产免费直播| 无码国内精品久久人妻蜜桃| 日本久久久久久久久久| 国产精品成人精品久久久| 99久久99这里只有免费费精品| 思思久久99热只有频精品66| 国产精品免费久久久久久久久 | 1000部精品久久久久久久久| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 激情伊人五月天久久综合| 久久婷婷五月综合97色直播| 欧美粉嫩小泬久久久久久久| 国产成人精品久久亚洲| 久久久久久久99精品免费观看| 久久天天躁狠狠躁夜夜avapp| 狠狠色丁香久久婷婷综合图片 | 亚洲中文字幕无码久久综合网| 人妻无码精品久久亚瑟影视 | 亚洲国产精品久久久天堂| 久久人人爽人人人人片av| 久久精品久久久久观看99水蜜桃|