scala 无论从数组的定义还是操作方面来说都跟java非常相似,但又有其独特的强大之处…

1、 定长数组

对于长度不变的数组,可以用scala中的Array。

//scala 里使用new实例化对象。 实例化过程中,可以用值和类型使对象参数化(创建对象的同时完成对它的设置)

val nums = new Array[Int](5);  //含5个整数的数组,元素默认初始化为0;

val arr = new Array[String](10);  //含10个字符串的数组,元素默认初始化为null;

arr(0) = “hello”; //数据赋值

val s = Array("hello", "world"); //长度为2的String数组。类型:自动推断。

注: jvm 中 scala的Array 是以 java数组的方式实现。 示例中的s 在jvm中的类型为 java.lang.String[];

2、变长数组

对于长度可变的数组,可以用scala中的ArrayBuffer。相应java中有ArrayList。

val nums = ArrayBuffer[Int]();

val nums = new ArrayBuffer[Int]           //一个空数组,准备存放整数。

nums += 1; //ArrayBuffer(1); 用+=在尾端添加元素。

nums +=(2,3,4,5) // ArrayBuffer(1,2,3,4,5); 在尾端添加多个元素。

nums ++=Array(6,7,8) //ArrayBuffer(1,2,3,4,5,6,7,8)  ++= 可以用来追加任何集合

nums.trimEnd(5) //ArrayBuffer(1,2,3)  移除最后五个元素。

nums.insert(2, 4)  //ArrayBuffer(1,2,4,3)  在下标2 前加一个元素 4;

nums.insert(2, 5, 6) //ArrayBuffer(1,2,5,6,4,3) 在下标2前插入多个元素

nums.remove(3) //ArrayBuffer(1,2,5,4,3) 移除第三个元素 (下标从0 始)

nums remove(2, 2)//ArrayBuffer(1,2, 3) 移除从第二个元素始的2个元素;

可变长数组转换为定长数据只用掉用其toArray方法。如 nums.toArray;

反过来,调用 a.toBuffer;  

3、遍历数组和数组缓冲

scala数组(数组缓冲)的遍历,可以用for循环进行。如:

for(i <- 0 until a.length)

println(a(i));

//变量i 取 0 到 a.length;  until 是 RichInt类的方法, 返回小于上限的方法。

4、数组转换

前边讲述了如何像Java那样操作数组。不过在scala中,数组还有更强大的功能。如过滤,转换等。例:

val a = Array(1,2,3,5,7);

val result = for(elem <- a) yield 2 * elem;

//result = Array(2,4,6,10,14); 此处转变并不会改变原数组的值,而是产生一个全新的数组。即for() yield 创建一个类型与原始集合相同的新集合。 数集合中的元素包含yield 之后的表达式的值,每个循环对应一个。

另外对集合处理时,你若只想处理满足条件的特定元素,这个需求可以通过守卫:for中的if 来实现。 若对a中奇数翻倍,则

for(elem <- a if elem % 2 == 1) yield 2 * elem;

5、常用算法

Array(1,2,4,6).sum  //计算数组的值

Array(1,4,2,6).sorted(_ < _); //排序 不改变原数组的值。

另外还有 append ,  appendAll, count, copyToArray, max等方法

scala 入门(2)--数组相关操作的更多相关文章

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

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

  2. Scala学习三——数组相关操作

    一.若长度固定则使用Array,若长度可能有变化则使用ArrayBuffer 固定长度数组: 如val nums=new Array[Int](10) //10个整型数组,所有元素初始化为0; val ...

  3. 快学Scala习题解答—第三章 数组相关操作

    3 数组相关操作  3.1 编写一段代码.将a设置为一个n个随机整数的数组,要求随机数介于0(包括)和n(不包括)之间  random和yield的使用 import scala.math.rando ...

  4. scala 对一个数组分组操作

    通常我们有一些需求,对一个数组两两进行翻转,通常就涉及到奇数偶数,否则就会出现数组index异常了,所以我们该怎么办呢? 虽然是一个入门级问题,但是我还是觉得这是一个很有意思的题目,因此写了一个对于通 ...

  5. 《快学Scala》第三章 数组相关操作

  6. 快学Scala-第三章 数组相关操作

    知识点: 1.定长数组 Array val nums = new Array[Int](10) //10个整数的数组,所有元素初始化为0 val a = new Array[String](10) / ...

  7. 【php】php数组相关操作函数片段

    下面这些都是我在工作中用到的函数,现在整理下. 判断是否是一个数组 function _is_array($value){ if (is_array($value)) { return true; } ...

  8. Ch03 数组相关操作 - 练习

    1. 编写一段代码,将a设置为一个n个随机数的数组,要求随机数介于0(包含)和n(不包含)之间. //import java.lang.Math def getArray(n:Int)={   val ...

  9. linux awk数组相关操作介绍

    用awk进行文本处理,少不了就是它的数组处理.那么awk数组有那些特点,一般常见运算又会怎么样呢.我们先看下以下的一些介绍,结合样例我们会解说下它的不同之处.在 awk 中数组叫做关联数组(assoc ...

随机推荐

  1. Qt之模型/视图(自定义按钮)(重绘QStyleOptionButton)

    http://blog.csdn.net/liang19890820/article/details/50974059#comments

  2. vijos国庆节模拟赛之繁星春水

    A.闪烁的繁星 题目:https://vijos.org/p/1881 题解:貌似做过小白逛公园或者序列操作都可以秒出吧,就是pushup函数比较麻烦,不过仔细想一想就知道了. 代码: #includ ...

  3. strcpy完整版 与 strcpy为什么有返回值

    一个标准的strcpy函数: 原本以为自己对strcpy还算比较了解,结果面试时还是悲剧了. 下面给出网上strcpy的得分版本: 2分 void strcpy( char *strDest, cha ...

  4. memory_target not supported on this system

  5. windows server2012域服务器降级的方法

    最近在一个新的网络环境里建立windows域服务器,准备建立主.备两台域服务器.在一台新服务器上面安装了windows2012R2并配置了DC服务.域和林的级别设置为Windows2012R2级别.在 ...

  6. JS点击按钮弹出窗口

    由于没有系统学习过JS,遇到一个需求:点击按钮,弹出一个独立的窗口. 在网上百度了一下,并没有找到满意的结果,最重要的是各种方法很复杂.最终,仔细研究了一下,原来只是需要只要一个简单的函数就能满足自己 ...

  7. DedeCMS安装及目录结构

    一.安装DedeCMS 1.下载DedeCMS安装包,我下载的版本是DedeCMS-V5.7-UTF8-SP1.tar.gz 官方下载地址 2.解压DedeCMS-V5.7-UTF8-SP1.tar. ...

  8. (转)重置Mac OS X管理员密码

    忘记Mac管理员密码怎么办?别担心,办法总会有的. [方法一] 开机按住option,选择Recovery HD(Snow Leopard插入光盘开机按住C) Snow Leopard系统:进入后在上 ...

  9. RTX51 Tiny实时操作系统学习笔记—初识RTX51 Tiny

     一,RTX51 Tiny简单介绍    RTX51 Tiny是一种实时操作系统(RTOS),能够用它来建立多个任务(函数)同一时候运行的应用(从宏观上看是同一时候运行的,但从微观上看,还是独立运行的 ...

  10. 复合命令A等效于$a

    时间:2014.06.28 地点:基地 ------------------------------------------------------------------------------- ...