一. 数组声明

  1. 定长数组
    scala> new Array[String](5)
    res1: Array[String] = Array(null, null, null, null, null) scala> Array("a","b",1)
    res4: Array[Any] = Array(a, b, 1)
  2. ArrayBuffer
    scala> import scala.collection.mutable.ArrayBuffer
    import scala.collection.mutable.ArrayBuffer scala> b += 11
    res0: b.type = ArrayBuffer(11) scala> val arr2 = Array(22,23)
    arr2: Array[Int] = Array(22, 23) scala> b ++= arr2
    res1: b.type = ArrayBuffer(11, 22, 23) scala> b.insert(1,0)
    scala> b
    res4: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(11, 0, 22, 23) scala> b.remove(2)
    scala> b
    res6: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(11, 0, 23)

二. 数组的操作

  1. 遍历

    //正序遍历
    scala> 0 until b.length
    res7: scala.collection.immutable.Range = Range(0, 1, 2)
    scala> for(i <- 0 until b.length) print(b(i)+",")
    11,0,23, //逆序遍历
    scala> (0 until b.length).reverse
    res10: scala.collection.immutable.Range = Range(2, 1, 0)
    scala> for(i <- (0 until b.length).reverse) print(b(i)+",")
    23,0,11, //简单遍历
    scala> for(i <- b) print(i+",")
    11,0,23,
  2. filter,map与yield,守卫

    for循环中使用守卫过滤元素,用yield产生集合的效果和对数组对象使用filter再使用map的效果相同

    scala> for(i <- b if i%2==1) yiel
    d i*2
    res17: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(22, 46) scala> b.filter(_%2 == 1).map(_*2)
    res15: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(22, 46)
  3. sum,max,sortWith,mkString

    scala> val arr = Array(1,2,3)
    arr: Array[Int] = Array(1, 2, 3) scala> arr.sum
    res28: Int = 6 scala> arr.max
    res29: Int = 3 scala> arr.sortWith(_>_)
    res38: Array[Int] = Array(3, 2, 1) // Array用mkString显示内容好,ArrayBuffer使用toString显式好
    scala> arr.mkString(",")
    res39: String = 1,2,3 scala> arr.toString
    res40: String = [I@22ab5262 scala> buffer.mkString(",")
    res41: String = 11,34,23 scala> buffer.toString
    res42: String = ArrayBuffer(11, 34, 23) //带变量类型
  4. 多维数组

    //规则的多维数组
    scala> Array.ofDim[Int](2,2)
    res46: Array[Array[Int]] = Array(Array(0, 0), Array(0, 0)) //不规则的多维数组
  5. scala的ArrayBuffer和java的ArrayList转换

    import java.io.{BufferedReader, InputStreamReader}
    
    import scala.collection.mutable.ArrayBuffer
    import scala.collection.JavaConversions.bufferAsJavaList //隐士转换 val cmd = ArrayBuffer("ls","-al","/home/lj")
    val builder: ProcessBuilder = new ProcessBuilder(cmd) //ProcessBuilder接受ArrayList,隐士转换后可接受ArrayBuffer
    val process: Process = builder.start()
    val reader: BufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream))
    var str = "";
    while((str=reader.readLine())!=null)
    println(str)

2. scala中的数组的更多相关文章

  1. Scala中的数组

    数组 数组的两种声明方式,建议声明数组时指定类型. 访问数组元素时获取数组下标 数组Array类本身有很多非常方便的方法 变长数组ArrayBuffer,能够动态增加元素,也可以实现与Array的互转 ...

  2. 【Scala篇】--Scala中集合数组,list,set,map,元祖

    一.前述 Scala在常用的集合的类别有数组,List,Set,Map,元祖. 二.具体实现 数组   1.创建数组 new Array[Int](10) 赋值:arr(0) = xxx Array[ ...

  3. Scala中的数组和集合操作

    package test /* 1.在scala集合中,Iterable是共同的Trait,Iterable要求继承者实现一些共同的方法,例如元素的遍历 * 2.Array是scala基础的数据结构, ...

  4. scala中的数组的转换操作

    1.共有两种操作 转换成一种新的数组 2.yield转换 3.函数式编程转换

  5. Programming In Scala笔记-第十七章、Scala中的集合类型

    本章主要介绍Scala中的集合类型,主要包括:Array, ListBuffer, Arraybuffer, Set, Map和Tuple. 一.序列 序列类型的对象中包含多个按顺序排列好的元素,可以 ...

  6. Scala学习(三)----数组相关操作

    数组相关操作 摘要: 本篇主要学习如何在Scala中操作数组.Java和C++程序员通常会选用数组或近似的结构(比如数组列表或向量)来收集一组元素.在Scala中,我们的选择更多,不过现在我们先假定不 ...

  7. Scala中Zip相关的函数

    在Scala中存在好几个Zip相关的函数,比如zip,zipAll,zipped 以及zipWithIndex等等.我们在代码中也经常看到这样的函数,这篇文章主要介绍一下这些函数的区别以及使用. 1. ...

  8. [原创]Scala学习:数组的基本操作,数组进阶操作,多维数组

    1.Scala中提供了一种数据结构-数组,其中存储相同类型的元素的固定大小的连续集合.数组用于存储数据的集合,但它往往是更加有用认为数组作为相同类型的变量的集合 2 声明数组变量: 要使用的程序的数组 ...

  9. Scala中的If判断&While&For循环

    If 判断: object TestScalaIf { def main(args: Array[String]): Unit = { // val resutlt = judge1(-100) // ...

随机推荐

  1. zoj3623 Battle Ships ——完全背包?简单DP!|| 泛化背包

    link:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3623 看起来像完全背包,但是物品价值是变化的,所以很多人搞的很复 ...

  2. Linux系统编程@多线程与多进程GDB调试

    博客内容参考自 http://www.cnblogs.com/xuxm2007/archive/2011/04/01/2002162.html http://blog.csdn.net/pbymw8i ...

  3. Linux 的多线程编程的高效开发经验(转)

    http://www.ibm.com/developerworks/cn/linux/l-cn-mthreadps/ 背景 Linux 平台上的多线程程序开发相对应其他平台(比如 Windows)的多 ...

  4. libGraphicsMagickWand.so: cannot open shared object file: No such file or directory stack traceback:

    参考博文:http://www.linuxidc.com/Linux/2016-07/133213.htm ==>> Check Passed, the num of bbox and f ...

  5. 论文笔记之:DeepCAMP: Deep Convolutional Action & Attribute Mid-Level Patterns

    DeepCAMP: Deep Convolutional Action & Attribute Mid-Level Patterns CVPR 2016 本文提出一种 分割图像 patch 的 ...

  6. ps色阶

    三原色

  7. css animation让图标不断旋转

    @keyframes rotating{from{transform:rotate(0)}to{transform:rotate(360deg)}} animation:rotating 1.2s l ...

  8. Data Pump(数据抽取)介绍

    从10g开始,Oracle提供更高效的Data Pump(即expdp/impdp)来进行数据的导入和导出,老的exp/imp还可以用,但已经不建议使用.注意:expdp/impdp和exp/imp之 ...

  9. jsp 页面json数据提交到后台spring处理举例

    0 前台: 'type'        : 'post', 'contentType' : 'application/json;charset=UTF-8', 'data'        : JSON ...

  10. [机器学习之13]降维技术——主成分分析PCA

    始终贯彻数据分析的一个大问题就是对数据和结果的展示,我们都知道在低维度下数据处理比较方便,因而数据进行简化成为了一个重要的技术.对数据进行简化的原因: 1.使得数据集更易用使用.2.降低很多算法的计算 ...