數組是一種可變的、可索引的數據集合。在Scala中用Array[T]的形式來表示Java中的數組形式 T[]。
valnumbers =Array(1,2,3,4)//聲明一個數組對象valfirst = numbers(0)// 讀取第一個元素numbers(3) =100// 替換第四個元素為100valbiggerNumbers = numbers.map(_ *2)// 所有元素乘2
Scala提供了大量的集合操作:
def ++[B](that: GenTraversableOnce[B]):Array[B]
合并集合,并返回一個新的數組,新數組包含左右兩個集合對象的內容。
vala =Array(1,2)valb =Array(3,4)valc = a ++ b//c中的內容是(1,2,3,4)
def ++:[B >: A, That](that: collection.Traversable[B])(implicit bf: CanBuildFrom[Array[T], B, That]): That
這個方法同上一個方法類似,兩個加號后面多了一個冒號,但是不同的是右邊操縱數的類型決定著返回結果的類型。下面代碼中List和LinkedList結合,返回結果是LinkedList類型
val a = List(1,2)? ? val b =scala.collection.mutable.LinkedList(3,4)? ? val c = a ++: b? ? println(c.getClass().getName())// c的類型是:scala.collection.mutable.LinkedList
def +:(elem: A):Array[A]
在數組前面添加一個元素,并返回新的對象,下面添加一個元素 0
vala = List(1,2)valc =0+: a// c中的內容是 (0,1,2)
def :+(elem: A):Array[A]
同上面的方法想法,在數組末尾添加一個元素,并返回新對象
def /:[B](z: B)(op: (B, T) ?6?0 B): B
對數組中所有的元素進行相同的操作 ,foldLeft的簡寫
vala = List(1,2,3,4)valc = (10/: a)(_+_)// 1+2+3+4+10vald = (10/: a)(_*_)// 1*2*3*4*10println("c:"+c)// c:20println("d:"+d)// d:240
def :\[B](z: B)(op: (T, B) ?6?0 B): B
foldRight的簡寫
def addString(b: StringBuilder): StringBuilder
將數組中的元素逐個添加到b中
vala = List(1,2,3,4)valb =newStringBuilder()valc = a.addString(b)// c中的內容是? 1234
def addString(b: StringBuilder, sep: String): StringBuilder
同上,每個元素用sep分隔符分開
vala = List(1,2,3,4)valb =newStringBuilder()valc = a.addString(b,",")? ? println("c:? "+c)// c:? 1,2,3,4
def addString(b: StringBuilder, start: String, sep: String, end: String): StringBuilder
同上,在首尾各加一個字符串,并指定sep分隔符
vala = List(1,2,3,4)valb =newStringBuilder()valc = a.addString(b,"{",",","}")? ? println("c:? "+c)// c:? {1,2,3,4}
def aggregate[B](z: ?6?0 B)(seqop: (B, T) ?6?0 B, combop: (B, B) ?6?0 B): B
聚合計算,aggregate是柯里化方法,參數是兩個方法,為了方便理解,我們把aggregate的兩個參數,分別封裝成兩個方法,并把計算過程打印出來。
defmain(args:Array[String]) {vala = List(1,2,3,4)valc = a.par.aggregate(5)(seqno,combine)? ? println("c:"+c)? }defseqno(m:Int,n:Int): Int ={vals ="seq_exp=%d+%d"println(s.format(m,n))returnm+n? }defcombine(m:Int,n:Int): Int ={vals ="com_exp=%d+%d"println(s.format(m,n))returnm+n? }/**
seq_exp=5+3
seq_exp=5+2
seq_exp=5+4
seq_exp=5+1
com_exp=6+7
com_exp=8+9
com_exp=13+17
c:30
*/
上面過程可以簡寫為
val c = a.par.aggregate(5)(_+_,_+_)
def apply(i: Int): T
同下面代碼,取出指定索引處的元素
valfirst = numbers(0)// 讀取第一個元素
def canEqual(that: Any): Boolean
判斷兩個對象是否可以進行比較
def charAt(index: Int): Char
獲取index索引處的字符,這個方法會執行一個隱式的轉換,將Array[T]轉換為 ArrayCharSequence,只有當T為char類型時,這個轉換才會發生。
valchars=Array('a','b','c')println("c:"+chars.charAt(0))//結果 a
def clone():Array[T]
創建一個副本
valchars=Array('a','b','c')? ? println(a.apply(2))? ? val newchars =chars.clone()
def collect[B](pf: PartialFunction[A, B]):Array[B]
通過執行一個并行計算(偏函數),得到一個新的數組對象
valchars =Array('a','b','c')valnewchars = chars.collect(fun)? println("newchars:"+newchars.mkString(","))//我們通過下面的偏函數,把chars數組的小寫a轉換為大寫的Avalfun:PartialFunction[Char,Char] = {case'a'=>'A'casex => x? }/**輸出結果是 newchars:A,b,c */
def collectFirst[B](pf: PartialFunction[T, B]): Option[B]
在序列中查找第一個符合偏函數定義的元素,并執行偏函數計算
valarr =Array(1,'a',"b")//定義一個偏函數,要求當被執行對象為Int類型時,進行乘100的操作,對于上面定義的對象arr來說,只有第一個元素符合要求valfun:PartialFunction[Any,Int] = {? ? case x:Int => x*100}//計算valvalue = arr.collectFirst(fun)? println("value:"+value)//另一種寫法valvalue = arr.collectFirst({case x:Int => x*100})
def combinations(n: Int): collection.Iterator[Array[T]]
排列組合,這個排列組合會選出所有包含字符不一樣的組合,對于 “abc”、“cba”,只選擇一個,參數n表示序列長度,就是幾個字符為一組
valarr =Array("a","b","c")valnewarr = arr.combinations(2)? ? newarr.foreach((item) => println(item.mkString(",")))/**
a,b
a,c
b,c
*/
def contains[A1 >: A](elem: A1): Boolean
序列中是否包含指定對象
def containsSlice[B](that: GenSeq[B]): Boolean
判斷當前序列中是否包含另一個序列
vala = List(1,2,3,4)valb = List(2,3)? ? println(a.containsSlice(b))//true
def copyToArray(xs:Array[A]): Unit
此方法還有兩個類似的方法,將數組拷貝到另一個數組 超過部分截斷 不夠的話 默認填充
將指定部分的數組內容拷貝到 xs 中 取余部分仍然保留xs原有的數據 如果xs沒有被初始化 默認以默認值填充
copyToArray(xs:Array[A], start: Int): Unit
vala =Array('a','b','c')valb :Array[Char] =newArray(5)a.copyToArray(b)/**b中元素 ['a','b','c',0,0]*/a.copyToArray(b,1)/**b中元素 [0,'a',0,0,0]*/a.copyToArray(b,1,2)/**b中元素 [0,'a','b',0,0]*/
def copyToBuffer[B >: A](dest: Buffer[B]): Unit
將數組中的內容拷貝到Buffer中
val a =Array('a','b','c')? ? val b:ArrayBuffer[Char]? =ArrayBuffer()? ? a.copyToBuffer(b)? ? println(b.mkString(","))
def corresponds[B](that: GenSeq[B])(p: (T, B) ?6?0 Boolean): Boolean
判斷兩個序列長度以及對應位置元素是否符合某個條件。如果兩個序列具有相同的元素數量并且p(x, y)=true,返回結果為true
下面代碼檢查a和b長度是否相等,并且a中元素是否小于b中對應位置的元素
val a =Array(1,2,3)val b =Array(4,5,6)println(a.corresponds(b)(_<_))//true
def count(p: (T) ?6?0 Boolean): Int
統計符合條件的元素個數,下面統計大于 2 的元素個數
val a =Array(1,2,3)? ? println(a.count({x:Int => x >2}))// count = 1
def diff(that: collection.Seq[T]):Array[T]
計算當前數組與另一個數組的不同。將當前數組中有在另一個數組中沒有出現的元素返回
vala =Array(1,2,3,4)valb =Array(4,5,6,7)valc = a.diff(b)println(c.mkString)//1,2,3
def distinct:Array[T]
去除當前集合中重復的元素,只保留一個
vala =Array(1,2,3,4,4,5,6,6)valc = a.distinctprintln(c.mkString(","))// 1,2,3,4,5,6
def drop(n: Int):Array[T]
將當前序列中前 n 個元素去除后,作為一個新序列返回
vala =Array(1,2,3,4)valc = a.drop(2)println(c.mkString(","))// 3,4
def dropRight(n: Int):Array[T]
功能同 drop,去掉尾部的 n 個元素
def dropWhile(p: (T) ?6?0 Boolean):Array[T]
去除當前數組中符合條件的元素,這個需要一個條件,就是從當前數組的第一個元素起,就要滿足條件,直到碰到第一個不滿足條件的元素結束(即使后面還有符合條件的元素),否則返回整個數組
//下面去除大于2的,第一個元素 3 滿足,它后面的元素 2 不滿足,所以返回 2,3,4vala =Array(3,2,3,4)valc = a.dropWhile( {x:Int => x >2} )println(c.mkString(","))//如果數組 a 是下面這樣,第一個元素就不滿足,所以返回整個數組 1, 2, 3,4vala =Array(1,2,3,4)
def endsWith[B](that: GenSeq[B]): Boolean
判斷是否以某個序列結尾
val a =Array(3,2,3,4)val b =Array(3,4)println(a.endsWith(b))//true
def exists(p: (T) ?6?0 Boolean): Boolean
判斷當前數組是否包含符合條件的元素
val a =Array(3,2,3,4) println(a.exists( {x:Int => x==3} ))//trueprintln(a.exists( {x:Int => x==30} ))//false
def filter(p: (T) ?6?0 Boolean):Array[T]
取得當前數組中符合條件的元素,組成新的數組返回
vala=Array(3,2,3,4)val b =a.filter( {x:Int => x>2} )println(b.mkString(","))//3,3,4
def filterNot(p: (T) ?6?0 Boolean):Array[T]
與上面的 filter 作用相反
def find(p: (T) ?6?0 Boolean): Option[T]
查找第一個符合條件的元素
vala =Array(1,2,3,4)valb = a.find( {x:Int => x>2} )println(b)// Some(3)
def flatMap[B](f: (A) ?6?0 GenTraversableOnce[B]):Array[B]
對當前序列的每個元素進行操作,結果放入新序列返回,參數要求是GenTraversableOnce及其子類
vala =Array(1,2,3,4)valb = a.flatMap(x=>1to x)println(b.mkString(","))/**
1,1,2,1,2,3,1,2,3,4
從1開始,分別于集合a的每個元素生成一個遞增序列,過程如下
1
1,2
1,2,3
1,2,3,4
*/
def flatten[U](implicit asTrav: (T) ?6?0 collection.Traversable[U], m: ClassTag[U]):Array[U]
將二維數組的所有元素聯合在一起,形成一個一維數組返回
val dArr =Array(Array(1,2,3),Array(4,5,6))val c = dArr.flattenprintln(c.mkString(","))//1,2,3,4,5,6
-def fold[A1 >: A](z: A1)(op: (A1, A1) ?6?0 A1): A1
對序列中的每個元素進行二元運算,和aggregate有類似的語義,但執行過程有所不同,我們來對比一下他們的執行過程。
因為aggregate需要兩個處理方法,所以我們定義一個combine方法
defseqno(m:Int,n:Int): Int ={vals ="seq_exp=%d+%d"println(s.format(m,n))returnm+n? }defcombine(m:Int,n:Int): Int ={vals ="com_exp=%d+%d"println(s.format(m,n))returnm+n? }vala =Array(1,2,3,4)valb = a.fold(5)(seqno)/** 運算過程
seq_exp=5+1
seq_exp=6+2
seq_exp=8+3
seq_exp=11+4
*/valc = a.par.aggregate(5)(seqno,combine)/** 運算過程
seq_exp=5+1
seq_exp=5+4
seq_exp=5+3
com_exp=8+9
seq_exp=5+2
com_exp=6+7
com_exp=13+17
*/
看上面的運算過程發現,fold中,seqno是把初始值順序和每個元素相加,把得到的結果與下一個元素進行運算
而aggregate中,seqno是把初始值與每個元素相加,但結果不參與下一步運算,而是放到另一個序列中,由第二個方法combine進行處理
-def foldLeft[B](z: B)(op: (B, T) ?6?0 B): B
從左到右計算,簡寫方式:def /:[B](z: B)(op: (B, T) ?6?0 B): B
defseqno(m:Int,n:Int): Int ={vals ="seq_exp=%d+%d"println(s.format(m,n))returnm+n? }vala =Array(1,2,3,4)valb = a.foldLeft(5)(seqno)/** 運算過程
seq_exp=5+1
seq_exp=6+2
seq_exp=8+3
seq_exp=11+4
*//**
簡寫 (5 /: a)(_+_)
*/
-def foldRight[B](z: B)(op: (B, T) ?6?0 B): B
從右到左計算,簡寫方式:def :\[B](z: B)(op: (T, B) ?6?0 B): B
defseqno(m:Int,n:Int): Int ={vals ="seq_exp=%d+%d"println(s.format(m,n))returnm+n? }vala =Array(1,2,3,4)valb = a.foldRight(5)(seqno)/** 運算過程
seq_exp=4+5
seq_exp=3+9
seq_exp=2+12
seq_exp=1+14
*//**
簡寫 (a :\ 5)(_+_)
*/
-def forall(p: (T) ?6?0 Boolean): Boolean
檢測序列中的元素是否都滿足條件 p,如果序列為空,返回true
vala =Array(1,2,3,4)valb = a.forall( {x:Int => x>0})//truevalb = a.forall( {x:Int => x>2})//false
-def foreach(f: (A) ?6?0 Unit): Unit
檢測序列中的元素是否都滿足條件 p,如果序列為空,返回true
vala =Array(1,2,3,4)valb = a.forall( {x:Int => x>0})//truevalb = a.forall( {x:Int => x>2})//false
-def foreach(f: (A) ?6?0 Unit): Unit
遍歷序列中的元素,進行 f 操作
vala =Array(1,2,3,4)? ? a.foreach(x => println(x*10))/**
10
20
30
40
*/
-def groupBy[K](f: (T) ?6?0 K): Map[K,Array[T]]
按條件分組,條件由 f 匹配,返回值是Map類型,每個key對應一個序列,下面代碼實現的是,把小于3的數字放到一組,大于3的放到一組,返回Map[String,Array[Int]]
val a =Array(1,2,3,4)? ? val b = a.groupBy( x=>x match {casexif(x <3)=>"small"case_=>"big"})
-def grouped(size: Int): collection.Iterator[Array[T]]
按指定數量分組,每組有 size 數量個元素,返回一個集合
vala =Array(1,2,3,4,5)valb = a.grouped(3).toListb.foreach((x) => println("第"+(b.indexOf(x)+1)+"組:"+x.mkString(",")))/**
第1組:1,2,3
第2組:4,5
*/
-def hasDefiniteSize: Boolean
檢測序列是否存在有限的長度,對應Stream這樣的流數據,返回false
vala=Array(1,2,3,4,5)println(a.hasDefiniteSize)//true
-def head: T
返回序列的第一個元素,如果序列為空,將引發錯誤
vala=Array(1,2,3,4,5)println(a.head)//1
-def headOption: Option[T]
返回Option類型對象,就是scala.Some 或者 None,如果序列是空,返回None
vala=Array(1,2,3,4,5)println(a.headOption)//Some(1)
-def indexOf(elem: T): Int
返回elem在序列中的索引,找到第一個就返回
vala=Array(1,3,2,3,4)println(a.indexOf(3))// return 1
-def indexOf(elem: T, from: Int): Int
返回elem在序列中的索引,可以指定從某個索引處(from)開始查找,找到第一個就返回
vala=Array(1,3,2,3,4)println(a.indexOf(3,2))// return 3
-def indexOfSlice[B >: A](that: GenSeq[B]): Int
檢測當前序列中是否包含另一個序列(that),并返回第一個匹配出現的元素的索引
val a =Array(1,3,2,3,4)? ? val b =Array(2,3)? ? println(a.indexOfSlice(b))// return 2
-def indexOfSlice[B >: A](that: GenSeq[B], from: Int): Int
檢測當前序列中是否包含另一個序列(that),并返回第一個匹配出現的元素的索引,指定從 from 索引處開始
val a =Array(1,3,2,3,2,3,4)? ? val b =Array(2,3)? ? println(a.indexOfSlice(b,3))// return 4
-def indexWhere(p: (T) ?6?0 Boolean): Int
返回當前序列中第一個滿足 p 條件的元素的索引
val a =Array(1,2,3,4)? ? println(a.indexWhere( {x:Int => x>3}))// return 3
-def indexWhere(p: (T) ?6?0 Boolean, from: Int): Int
返回當前序列中第一個滿足 p 條件的元素的索引,可以指定從 from 索引處開始
val a =Array(1,2,3,4,5,6)? ? println(a.indexWhere( {x:Int => x>3},4))// return 4
-def indices: collection.immutable.Range
返回當前序列索引集合
vala =Array(10,2,3,40,5)valb = a.indices? ? println(b.mkString(","))// 0,1,2,3,4
-def init:Array[T]
返回當前序列中不包含最后一個元素的序列
vala =Array(10,2,3,40,5)valb = a.init? ? println(b.mkString(","))// 10, 2, 3, 40
-def inits: collection.Iterator[Array[T]]
對集合中的元素進行 init 操作,該操作的返回值中, 第一個值是當前序列的副本,包含當前序列所有的元素,最后一個值是空的,對頭尾之間的值進行init操作,上一步的結果作為下一步的操作對象
vala =Array(1,2,3,4,5)valb = a.inits.toListfor(i <-1to b.length){vals ="第%d個值:%s"println(s.format(i,b(i-1).mkString(",")))? ? }/**計算結果
第1個值:1,2,3,4,5
第2個值:1,2,3,4
第3個值:1,2,3
第4個值:1,2
第5個值:1
第6個值
*/
-def intersect(that: collection.Seq[T]):Array[T]
取兩個集合的交集
vala =Array(1,2,3,4,5)valb =Array(3,4,6)valc = a.intersect(b)? ? println(c.mkString(","))//return 3,4
-def isDefinedAt(idx: Int): Boolean
判斷序列中是否存在指定索引
vala=Array(1,2,3,4,5)? ? println(a.isDefinedAt(1))// trueprintln(a.isDefinedAt(10))// false
-def isEmpty: Boolean
判斷當前序列是否為空
-def isTraversableAgain: Boolean
判斷序列是否可以反復遍歷,該方法是GenTraversableOnce中的方法,對于 Traversables 一般返回true,對于 Iterators 返回 false,除非被復寫
-def iterator: collection.Iterator[T]
對序列中的每個元素產生一個 iterator
vala =Array(1,2,3,4,5)valb = a.iterator//此時就可以通過迭代器訪問 b
-def last: T
取得序列中最后一個元素
vala=Array(1,2,3,4,5)? ? println(a.last)// return? 5
-def lastIndexOf(elem: T): Int
取得序列中最后一個等于 elem 的元素的位置
vala=Array(1,4,2,3,4,5)? ? println(a.lastIndexOf(4))// return? 4
-def lastIndexOf(elem: T, end: Int): Int
取得序列中最后一個等于 elem 的元素的位置,可以指定在 end 之前(包括)的元素中查找
vala=Array(1,4,2,3,4,5)? ? println(a.lastIndexOf(4,3))// return? 1
-def lastIndexOfSlice[B >: A](that: GenSeq[B]): Int
判斷當前序列中是否包含序列 that,并返回最后一次出現該序列的位置處的索引
val a =Array(1,4,2,3,4,5,1,4)? ? val b =Array(1,4)? ? println(a.lastIndexOfSlice(b))// return? 6
-def lastIndexOfSlice[B >: A](that: GenSeq[B], end: Int): Int
判斷當前序列中是否包含序列 that,并返回最后一次出現該序列的位置處的索引,可以指定在 end 之前(包括)的元素中查找
val a =Array(1,4,2,3,4,5,1,4)? ? val b =Array(1,4)? ? println(a.lastIndexOfSlice(b,4))// return? 0
-def lastIndexWhere(p: (T) ?6?0 Boolean): Int
返回當前序列中最后一個滿足條件 p 的元素的索引
val a =Array(1,4,2,3,4,5,1,4)? ? val b =Array(1,4)? ? println(a.lastIndexWhere( {x:Int => x<2}))// return? 6
-def lastIndexWhere(p: (T) ?6?0 Boolean, end: Int): Int
返回當前序列中最后一個滿足條件 p 的元素的索引,可以指定在 end 之前(包括)的元素中查找
val a =Array(1,4,2,3,4,5,1,4)? ? val b =Array(1,4)? ? println(a.lastIndexWhere( {x:Int => x<2},2))// return? 0
-def lastOption: Option[T]
返回當前序列中最后一個對象
vala=Array(1,2,3,4,5)? ? println(a.lastOption)// return? Some(5)
-deflength: Int
返回當前序列中元素個數
vala=Array(1,2,3,4,5)? ? println(a.length)// return? 5
-def lengthCompare(len: Int): Int
比較序列的長度和參數 len,根據二者的關系返回不同的值,比較規則是
x <0ifthis.lengthlength==lenx >0ifthis.length>len
-def map[B](f: (A) ?6?0 B):Array[B]
對序列中的元素進行 f 操作
vala =Array(1,2,3,4,5)valb = a.map( {x:Int => x*10})? ? println(b.mkString(","))// 10,20,30,40,50
-def max: A
返回序列中最大的元素
vala=Array(1,2,3,4,5)? ? println(a.max)// return? 5
-def maxBy[B](f: (A) ?6?0 B): A
返回序列中第一個符合條件的最大的元素
val a =Array(1,2,3,4,5)? ? println(a.maxBy( {x:Int => x >2}))// return? 3
-def mkString: String
將所有元素組合成一個字符串
vala=Array(1,2,3,4,5)? ? println(a.mkString)// return? 12345
-def mkString(sep: String): String
將所有元素組合成一個字符串,以 sep 作為元素間的分隔符
vala=Array(1,2,3,4,5)? ? println(a.mkString(","))// return? 1,2,3,4,5
-def mkString(start: String, sep: String, end: String): String
將所有元素組合成一個字符串,以 start 開頭,以 sep 作為元素間的分隔符,以 end 結尾
vala=Array(1,2,3,4,5)? ? println(a.mkString("{",",","}"))// return? {1,2,3,4,5}
-def nonEmpty: Boolean
判斷序列不是空
-def padTo(len: Int, elem: A):Array[A]
后補齊序列,如果當前序列長度小于 len,那么新產生的序列長度是 len,多出的幾個位值填充 elem,如果當前序列大于等于 len ,則返回當前序列
vala =Array(1,2,3,4,5)valb = a.padTo(7,9)//需要一個長度為 7? 的新序列,空出的填充 9println(b.mkString(","))// return? 1,2,3,4,5,9,9
-def par: ParArray[T]
返回一個并行實現,產生的并行序列,不能被修改
vala =Array(1,2,3,4,5)valb = a.par//? "ParArray" size = 5
-def partition(p: (T) ?6?0 Boolean): (Array[T],Array[T])
按條件將序列拆分成兩個新的序列,滿足條件的放到第一個序列中,其余的放到第二個序列,下面以序列元素是否是 2 的倍數來拆分
val a =Array(1,2,3,4,5)? ? val b:(Array[Int],Array[Int]) = a.partition( {x:Int => x %2==0})? ? println(b._1.mkString(","))// return? 2,4println(b._2.mkString(","))// return? 1,3,5
-def patch(from: Int, that: GenSeq[A], replaced: Int):Array[A]
批量替換,從原序列的 from 處開始,后面的 replaced 數量個元素,將被替換成序列 that
vala =Array(1,2,3,4,5)valb =Array(3,4,6)valc = a.patch(1,b,2)? ? println(c.mkString(","))// return 1,3,4,6,4,5/**從 a 的第二個元素開始,取兩個元素,即 2和3 ,這兩個元素被替換為 b的內容*/
-def permutations: collection.Iterator[Array[T]]
排列組合,他與combinations不同的是,組合中的內容可以相同,但是順序不能相同,combinations不允許包含的內容相同,即使順序不一樣
vala =Array(1,2,3,4,5)valb = a.permutations.toList// b 中將有120個結果,知道排列組合公式的,應該不難理解吧/**如果是combinations*/valb = a.combinations(5).toList// b 中只有一個,因為不管怎樣排列,都是這5個數字組成,所以只能保留第一個
-def prefixLength(p: (T) ?6?0 Boolean): Int
給定一個條件 p,返回一個前置數列的長度,這個數列中的元素都滿足 p[沒看懂]
vala =Array(1,2,3,4,1,2,3,4)valb = a.prefixLength( {x:Int => x<3})// b = 2
-def product: A
返回所有元素乘積的值
val a =Array(1,2,3,4,5)? ? val b = a.product? ? ? // b =120(1*2*3*4*5)
-def reduce[A1 >: A](op: (A1, A1) ?6?0 A1): A1
同 fold,不需要初始值
valfun:PartialFunction[Any,Int] = {case'a'=>'A'casex:Int => x*100}vala =Array(1,2,3,4,5)valb = a.reduce(seqno)? println(b)// 15/**
seq_exp=1+2
seq_exp=3+3
seq_exp=6+4
seq_exp=10+5
*/
-def reduceLeft[B >: A](op: (B, T) ?6?0 B): B
從左向右計算
-def reduceRight[B >: A](op: (T, B) ?6?0 B): B
從右向左計算
-def reduceLeftOption[B >: A](op: (B, T) ?6?0 B): Option[B]
計算Option,參考reduceLeft
-def reduceRightOption[B >: A](op: (T, B) ?6?0 B): Option[B]
計算Option,參考reduceRight
-def reverse:Array[T]
反轉序列
vala =Array(1,2,3,4,5)valb = a.reverse? ? println(b.mkString(","))//5,4,3,2,1
-def reverseIterator: collection.Iterator[T]
反向生成迭代
-def reverseMap[B](f: (A) ?6?0 B):Array[B]
同 map 方向相反
vala =Array(1,2,3,4,5)valb = a.reverseMap( {x:Int => x*10} )? ? println(b.mkString(","))// 50,40,30,20,10
-def sameElements(that: GenIterable[A]): Boolean
判斷兩個序列是否順序和對應位置上的元素都一樣
val a =Array(1,2,3,4,5)? ? val b =Array(1,2,3,4,5)? ? println(a.sameElements(b))// trueval c =Array(1,2,3,5,4)? ? println(a.sameElements(c))// false
-def scan[B >: A, That](z: B)(op: (B, B) ?6?0 B)(implicit cbf: CanBuildFrom[Array[T], B, That]): That
用法同 fold,scan會把每一步的計算結果放到一個新的集合中返回,而 fold 返回的是單一的值
vala =Array(1,2,3,4,5)valb = a.scan(5)(seqno)? ? println(b.mkString(","))// 5,6,8,11,15,20
-def scanLeft[B, That](z: B)(op: (B, T) ?6?0 B)(implicit bf: CanBuildFrom[Array[T], B, That]): That
從左向右計算
-def scanRight[B, That](z: B)(op: (T, B) ?6?0 B)(implicit bf: CanBuildFrom[Array[T], B, That]): That
從右向左計算
-def segmentLength(p: (T) ?6?0 Boolean, from: Int): Int
從序列的 from 處開始向后查找,所有滿足 p 的連續元素的長度
vala =Array(1,2,3,1,1,1,1,1,4,5)valb = a.segmentLength( {x:Int => x <3},3)// 5
-def seq: collection.mutable.IndexedSeq[T]
產生一個引用當前序列的 sequential 視圖
-def size: Int
序列元素個數,同length
-def slice(from: Int, until: Int):Array[T]
取出當前序列中,from 到 until 之間的片段
vala =Array(1,2,3,4,5)valb = a.slice(1,3)? ? println(b.mkString(","))// 2,3
-def sliding(size: Int): collection.Iterator[Array[T]]
從第一個元素開始,每個元素和它后面的 size - 1 個元素組成一個數組,最終組成一個新的集合返回,當剩余元素不夠 size 數,則停止
vala =Array(1,2,3,4,5)valb = a.sliding(3).toListfor(i<-0to b.length-1){vals ="第%d個:%s"println(s.format(i,b(i).mkString(",")))? ? }/**
第0個:1,2,3
第1個:2,3,4
第2個:3,4,5
*/
-def sliding(size: Int, step: Int): collection.Iterator[Array[T]]
從第一個元素開始,每個元素和它后面的 size - 1 個元素組成一個數組,最終組成一個新的集合返回,當剩余元素不夠 size 數,則停止
該方法,可以設置步進 step,第一個元素組合完后,下一個從 上一個元素位置+step后的位置處的元素開始
vala =Array(1,2,3,4,5)valb = a.sliding(3,2).toList//第一個從1開始, 第二個從3開始,因為步進是 2for(i<-0to b.length-1){vals ="第%d個:%s"println(s.format(i,b(i).mkString(",")))? ? }/**
第0個:1,2,3
第1個:3,4,5
*/
-def sortBy[B](f: (T) ?6?0 B)(implicit ord: math.Ordering[B]):Array[T]
按指定的排序規則排序
vala =Array(3,2,1,4,5)valb = a.sortBy( {x:Int => x})? ? println(b.mkString(","))// 1,2,3,4,5
-def sortWith(lt: (T, T) ?6?0 Boolean):Array[T]
自定義排序方法 lt
vala =Array(3,2,1,4,5)valb = a.sortWith(_.compareTo(_) >0)// 大數在前println(b.mkString(","))// 5,4,3,2,1
-def sorted[B >: A](implicit ord: math.Ordering[B]):Array[T]
使用默認的排序規則對序列排序
vala =Array(3,2,1,4,5)valb = a.sorted? ? ? ? println(b.mkString(","))// 1,2,3,4,5
-def span(p: (T) ?6?0 Boolean): (Array[T],Array[T])
分割序列為兩個集合,從第一個元素開始,直到找到第一個不滿足條件的元素止,之前的元素放到第一個集合,其它的放到第二個集合
vala =Array(3,2,1,4,5)valb = a.span( {x:Int => x >2})? ? println(b._1.mkString(","))//? 3println(b._2.mkString(","))//? 2,1,4,5
-def splitAt(n: Int): (Array[T],Array[T])
從指定位置開始,把序列拆分成兩個集合
vala =Array(3,2,1,4,5)valb = a.splitAt(2)? ? println(b._1.mkString(","))//? 3,2println(b._2.mkString(","))//? 1,4,5
-def startsWith[B](that: GenSeq[B], offset: Int): Boolean
從指定偏移處,是否以某個序列開始
val a =Array(0,1,2,3,4,5)? ? val b =Array(1,2)? ? println(a.startsWith(b,1))//? true
-def startsWith[B](that: GenSeq[B]): Boolean
是否以某個序列開始
val a =Array(1,2,3,4,5)? ? val b =Array(1,2)? ? println(a.startsWith(b))//? true
-def stringPrefix: String
返回 toString 結果的前綴
vala=Array(0,1,2,3,4,5)? ? println(a.toString())//[I@3daa57fbval b =a.stringPrefix? ? println(b)//[I
-def subSequence(start: Int, end: Int): CharSequence
返回 start 和 end 間的字符序列
valchars =Array('a','b','c','d')valb = chars.subSequence(1,3)? ? println(b.toString)//? bc
-def sum: A
序列求和,元素需為Numeric[T]類型
vala=Array(1,2,3,4,5)? ? val b =a.sum//? 15
-def tail:Array[T]
返回除了當前序列第一個元素的其它元素組成的序列
vala =Array(1,2,3,4,5)valb = a.tail//? 2,3,4,5
-def take(n: Int):Array[T]
返回當前序列中前 n 個元素組成的序列
vala =Array(1,2,3,4,5)valb = a.take(3)//? 1,2,3
-def takeRight(n: Int):Array[T]
返回當前序列中,從右邊開始,選擇 n 個元素組成的序列
vala =Array(1,2,3,4,5)valb = a.takeRight(3)//? 3,4,5
-def takeWhile(p: (T) ?6?0 Boolean):Array[T]
返回當前序列中,從第一個元素開始,滿足條件的連續元素組成的序列
vala =Array(1,2,3,4,5)valb = a.takeWhile( {x:Int => x <3})//? 1,2
-def toArray:Array[A]
轉換成Array類型
-def toBuffer[A1 >: A]: Buffer[A1]
轉換成 Buffer 類型
-def toIndexedSeq: collection.immutable.IndexedSeq[T]
轉換成 IndexedSeq 類型
-def toIterable: collection.Iterable[T]
轉換成可迭代的類型
-def toIterator: collection.Iterator[T]
同 iterator 方法
-def toList: List[T]
同 List 類型
-def toMap[T, U]: Map[T, U]
同 Map 類型,需要被轉化序列中包含的元素時 Tuple2 類型數據
valchars =Array(("a","b"),("c","d"),("e","f"))valb = chars.toMap? ? println(b)//Map(a -> b, c -> d, e -> f)
-def toSeq: collection.Seq[T]
同 Seq 類型
-def toSet[B >: A]: Set[B]
同 Set 類型
-def toStream: collection.immutable.Stream[T]
同 Stream 類型
-def toVector: Vector[T]
同 Vector 類型
-def transpose[U](implicit asArray: (T) ?6?0Array[U]):Array[Array[U]]
矩陣轉換,二維數組行列轉換
val chars =Array(Array("a","b"),Array("c","d"),Array("e","f"))? ? val b = chars.transpose? ? println(b.mkString(","))
-def union(that: collection.Seq[T]):Array[T]
聯合兩個序列,同操作符 ++
vala =Array(1,2,3,4,5)valb =Array(6,7)valc = a.union(b)? ? println(c.mkString(","))// 1,2,3,4,5,6,7
-def unzip[T1, T2](implicit asPair: (T) ?6?0 (T1, T2), ct1: ClassTag[T1], ct2: ClassTag[T2]): (Array[T1],Array[T2])
將含有兩個元素的數組,第一個元素取出組成一個序列,第二個元素組成一個序列
valchars =Array(("a","b"),("c","d"))valb = chars.unzip? ? println(b._1.mkString(","))//a,cprintln(b._2.mkString(","))//b,d
-def unzip3[T1, T2, T3](implicit asTriple: (T) ?6?0 (T1, T2, T3), ct1: ClassTag[T1], ct2: ClassTag[T2], ct3: ClassTag[T3]): (Array[T1],Array[T2],Array[T3])
將含有三個元素的三個數組,第一個元素取出組成一個序列,第二個元素組成一個序列,第三個元素組成一個序列
val chars =Array(("a","b","x"),("c","d","y"),("e","f","z"))? ? val b = chars.unzip3println(b._1.mkString(","))//a,c,eprintln(b._2.mkString(","))//b,d,fprintln(b._3.mkString(","))//x,y,z
-def update(i: Int, x: T): Unit
將序列中 i 索引處的元素更新為 x
vala=Array(1,2,3,4,5)a.update(1,9)? ? println(a.mkString(","))//1,9,3,4,5
-def updated(index: Int, elem: A):Array[A]
將序列中 i 索引處的元素更新為 x ,并返回替換后的數組
vala =Array(1,2,3,4,5)valb = a.updated(1,9)? ? println(b.mkString(","))//1,9,3,4,5
-def view(from: Int, until: Int): IndexedSeqView[T,Array[T]]
返回 from 到 until 間的序列,不包括 until 處的元素
vala =Array(1,2,3,4,5)valb = a.view(1,3)? ? println(b.mkString(","))//2,3
-def withFilter(p: (T) ?6?0 Boolean): FilterMonadic[T,Array[T]]
根據條件 p 過濾元素
val a =Array(1,2,3,4,5)? ? val b = a.withFilter( {x:Int => x>3}).map(x=>x)? ? println(b.mkString(","))//4,5
-def zip[B](that: GenIterable[B]):Array[(A, B)]
將兩個序列對應位置上的元素組成一個pair序列
vala =Array(1,2,3,4,5)valb =Array(5,4,3,2,1)valc = a.zip(b)? ? println(c.mkString(","))//(1,5),(2,4),(3,3),(4,2),(5,1)
-def zipAll[B](that: collection.Iterable[B], thisElem: A, thatElem: B):Array[(A, B)]
同 zip ,但是允許兩個序列長度不一樣,不足的自動填充,如果當前序列端,空出的填充為 thisElem,如果 that 短,填充為 thatElem
vala =Array(1,2,3,4,5,6,7)valb =Array(5,4,3,2,1)valc = a.zipAll(b,9,8)//(1,5),(2,4),(3,3),(4,2),(5,1),(6,8),(7,8)vala =Array(1,2,3,4)valb =Array(5,4,3,2,1)valc = a.zipAll(b,9,8)//(1,5),(2,4),(3,3),(4,2),(9,1)
-def zipWithIndex:Array[(A, Int)]
序列中的每個元素和它的索引組成一個序列
vala =Array(10,20,30,40)valb = a.zipWithIndex? ? println(b.mkString(","))//(10,0),(20,1),(30,2),(40,3)