数组

-----------------------------------

  0.若长度固定则用Array,若长度可能变化则使用ArrayBuffer

  1.提供初始值的时候不要使用new。

  2.用()来访问元素

  3.使用for(elem<-arr)来遍历元素

  4.用for(elem<- arr if ....)...yield...来将原数组转换成新数组

  5.Scala数组和java数组可以互操作;用ArrayBuffer,使用scala.collection.JavaConversions中的转换函数。

  1.定长数组

    (1)如果需要一个长度不变的一个数组,可以用Array

      val nums = new Array[Int](10)  //10个整数的数组,将所有元素初始化为0

      val a = new Array[String](10)  //10个字符串数组,所有元素初始化都为null

      val s = Array("Hello","World")  //长度为2的Array[String]----类型是推断出来的

                    //说明:已经提供初始值就不需要new

      s(0) = "Goodbye"      //Array("Goodbye","World"),使用()而不是[]来访问元素

  2.边长数组:数组缓冲。对于长度按照需要变化的数组,java有ArrayList。Scala中有ArrayBuffer

    

import scala.collection.mutable.ArrayBuffer
val b = ArrayBuffer[Int]() //或者new ArrayBuffer[Int],一个空的数组缓冲,用于存放整数
b+= //ArrayBuufer(1),用+=在尾端添加元素
b+=(,,,) //ArrayBuffer(1,1,2,3,5),在尾端添加多个元素,用括号括起来
b++=Array(,,) //ArrayBuffer(1,1,2,3,5,8,13,21),可以用++=操作符追加任何集合
b.timeEnd() //ArrayBuffer(1,1,2),移除后面5个元素

  在数组尾部添加或者溢出元素是比较高效的操作,也可以在任意位置插入或者移除元素,但是这样就没有那么高效了,所有在那个之后的元素都必须被平移。如:

b.insert(,)    //ArrayBuffer(1,1,6,2),这是在下标2之前进行插入6操作
b.insert(,,,) //ArrayBuffer(1,1,7,8,9,6,2),可以插入任意多的元素
b.remove() //Array(1,1,8,9,6,2),移除下标为2上的元素
b.remove(,) //ArrayBuffer(1,1,2),第二个参数是要移除多少个元素

有的时候需要构建一个Array,但是不知道最终需要装进去多少个元素。在这种情况下先构建一个缓冲数组,然后调用:b.toArray

3.遍历数组和数组缓冲

for(i<- until a.length)
println(i+":"+a(i)) //这个地方变量i的取值范围是从0到a.length-1.until是RichInt类的方法,返回所有小于(但是不包括)上限的数组
  如 0 until 10 //Range(0,1,2,3,4,5,6,7,8,9)

  如果想要每两个元素一条,可以让i这样进行遍历

  

//如果想要每两个元素一跳,可以这样遍历
until (a.length,) //Range(0,2,4...)
//如果要从数组尾端开始,遍历方法如下:
( until a.length).reverse //Range(...,2,1,0)
//如果在循环体中不需要用到数组下标,可以直接这样访问数组
for(elem <- a)
println(elem)

//定长数组的操作

var arr= new Array[Int]();    //创建一个定长数组,元素都为0
arr = Array(,,) //将arr中的0,1,2号位置上的0,0,0换成1,2,3
arr() //取出第一个位置上的元素

//边长数组操作

import scala.collection.mutable.ArrayBuffer    //先进行导包操作
var buf = ArrayBuffer[Int]() //创建数组缓冲区对象

//溢出末尾两个元素

buf.trimEnd()    //移除末尾两个元素
buf.trimStart() //移除开始两个元素

//yield  产生新值

val a = Array(,,,,)
val result = for(elem<- a) yield * elem //产生result是(4,6,10,14,22)

//守卫条件

//  返回大于5的偶数,类型为Vector
val items = for(i <- to if i % == if i > ) yield i;

5.常用的算法

Array(,,,).sum    //19    对ArrayBuffer同样适用,使用sum方法,元素类型必须是数值类型:要么是整数,要么是浮点型或者BigInteger/BigDecimal
ArrayBuffer("Mary","had","a","little","lamb").max    //返回little,max和min输出数组或者数组缓冲区中最大或者最小的元素

//sorted()方法

val b = ArrayBuffer(,,,)
val bSorted = b.sourted(_<_) //ArrayBuffer(1,7,2,9) val bsorted=b.sorted(_>_) //ArrayBuffer(9,7,2,1)

//可以直接对一个数组进行排序,但是不能对缓冲区进行排序

val a =Array(1,7,2,9)
scala.util.Sorting.quickSort(a) // Array(1,2,7,9)
//如果想要显示数组或者缓冲区的内容,可以使用mkString方法,允许在指定的元素之间的分隔符
a.mkString("and" ) //"1 and 2 and 7 and 9"
a.mkString("<",",",">") //"<1,2,7,9>" //相对于toString相比:
a.toString //这是java的方法,毫无意义
b.toString //"ArrayBuffer(1,7,2,9)"

  7.多维数组

  和java一样,多维数组是通过数组的数组来实现的。如Double的二维数组类型为Array[Array[Double]],构造这样的一个数组可以用ofDim方法:  var matrix=Array.ofDim[Double]{3,4}  //定义一个3行4列的二维数组

  要访问其中的元素,使用两对圆括号:matrix(row)(column)=42

  8.与java的互操作,导入转换类,使用的是隐式转换,

  scala>import scala.collection.javaConversions.bufferAsJavaList

  而要访问其中的元素,每一行的长度不相同

Scala学习笔记(3)的更多相关文章

  1. 基于.net的分布式系统限流组件 C# DataGridView绑定List对象时,利用BindingList来实现增删查改 .net中ThreadPool与Task的认识总结 C# 排序技术研究与对比 基于.net的通用内存缓存模型组件 Scala学习笔记:重要语法特性

    基于.net的分布式系统限流组件   在互联网应用中,流量洪峰是常有的事情.在应对流量洪峰时,通用的处理模式一般有排队.限流,这样可以非常直接有效的保护系统,防止系统被打爆.另外,通过限流技术手段,可 ...

  2. Scala学习笔记及与Java不同之处总结-从Java开发者角度

    Scala与Java具有很多相似之处,但又有很多不同.这里主要从一个Java开发者的角度,总结在使用Scala的过程中所面临的一些思维转变. 这里仅仅是总结了部分两种语言在开发过程中的不同,以后会陆续 ...

  3. Scala学习笔记之:tuple、array、Map

    [TOC] 本文<快学Scala>的笔记 tuple学习笔记 tuple的定义 对偶是元组(tuple)的最简单形态--元组是不同类型的值的聚集. 元组的值是通过将单个值包含在圆括号中构成 ...

  4. 机器学习(三)--- scala学习笔记

    Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...

  5. 【大数据】Scala学习笔记

    第 1 章 scala的概述1 1.1 学习sdala的原因 1 1.2 Scala语言诞生小故事 1 1.3 Scala 和 Java  以及 jvm 的关系分析图 2 1.4 Scala语言的特点 ...

  6. 原创:Scala学习笔记(不断更新)

    Scala是一种函数式语言和面向对象语言结合的新语言,本笔记中就零散记下学习scala的一些心得,主要侧重函数式编程方面. 1. 以递归为核心控制结构. 实现循环处理的方式有三种:goto,for/w ...

  7. scala 学习笔记(04) OOP(上)主从构造器/私有属性/伴生对象(单例静态类)/apply方法/嵌套类

    一.主从构造器 java中构造函数没有主.从之分,只有构造器重载,但在scala中,每个类都有一个主构造器,在定义class时,如果啥也没写,默认有一个xxx()的主构造器 class Person ...

  8. scala 学习笔记(03) 参数缺省值、不定个数参数、类的属性(Property)、泛型初步

    继续学习,这一篇主要是通过scala来吐槽java的,同样是jvm上的语言,差距咋就这么大呢? 作为一个有.NET开发经验的程序员,当初刚接触java时,相信很多人对java语言有以下不爽(只列了极小 ...

  9. scala学习笔记

    一 入门 为了增加编程趣味和技能,学习新语言,体会函数式编程和简易的并发管理模型,了解日渐活跃的Spark,尝试下Scala.Scala = Scalable language,作者是Martin O ...

  10. Scala学习笔记1(安装)

    到 官网下载scala tar包  http://www.scala-lang.org/download/ mac Finder里双击解压. 改名成scala 进命令行, mv ~/Downloads ...

随机推荐

  1. HBase2.0新特性解析

    作者 | 个推大数据运维工程师 行者 升级背景 个推作为专业的数据智能服务商,在业务开展过程中存在海量的数据存储与查询的需求,为此个推选用了高可靠.高性能.面向列.可伸缩的分布式数据存储系统--HBa ...

  2. C++入门经典-例5.6-指针与const

    1:同其他数据类型一样,指针也有常量,使用const关键字定义,形式如下: int i=9; int *const p=&i;//无法改变内存指向 *p=3; 将关键字const放在标识符前, ...

  3. HTML功能框架

    起始预定义函数 function $(obj) { return document.getElementById(obj); } 1.用户登陆框架 <!DOCTYPE html> < ...

  4. spark中使用的内存文件系统-Tachyon FS 简介

    转自:http://blog.csdn.net/u014252240/article/details/41810849  发布人:南京大学PASA大数据实验室顾荣 1. Tachyon是什么 Tach ...

  5. EasyPHP(php集成环境)下载 v5.4.6官方安装版

    EasyPHP版本:12.1(32位) PHP版本:5.4.6 MYSQL版本:5.5.27 APACHE版本:2.4.2 下载地址请点击

  6. Web(八) commons-fileupload上传下载

    在网上看见一篇不错的文章,写的详细. 以下内容引用那篇博文.转载于<http://www.cnblogs.com/whgk/p/6479405.html>,在此仅供学习参考之用. 一.上传 ...

  7. 90子集II

    题目:给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集).说明:解集不能包含重复的子集. 输入:[1,2,2]   输出:[[2],[1],[1,2,2],[2,2],[1 ...

  8. document的属性操作

    document对象: 1.直接操作: 对象.属性 = 值; 如下面一段代码: <a href  = "...">跳转</a> <script> ...

  9. jenkins 配置 gitlab webhook 实现自动发布

    测试环境需要git提交代码后,Jenkins自动部署,需要gitlab配置project webhook. 1,Jenkins版本2.89  gitlab 8.11 2,Jenkins需要安装插件:G ...

  10. python文档的数据读取,把读取数据写入到新的表里

    目的:接口自动化过程需要从表格文件读取,然后把结果写到表格中.没有多余内容全部是精华! 读取文件1 读取文件2 代码如下图: # -*-coding:utf-8 -*-# Author:wangjun ...