2. scala中的数组
一. 数组声明
- 定长数组
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)
- 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)
二. 数组的操作
遍历
//正序遍历
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,
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)
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) //带变量类型多维数组
//规则的多维数组
scala> Array.ofDim[Int](2,2)
res46: Array[Array[Int]] = Array(Array(0, 0), Array(0, 0)) //不规则的多维数组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中的数组的更多相关文章
- Scala中的数组
数组 数组的两种声明方式,建议声明数组时指定类型. 访问数组元素时获取数组下标 数组Array类本身有很多非常方便的方法 变长数组ArrayBuffer,能够动态增加元素,也可以实现与Array的互转 ...
- 【Scala篇】--Scala中集合数组,list,set,map,元祖
一.前述 Scala在常用的集合的类别有数组,List,Set,Map,元祖. 二.具体实现 数组 1.创建数组 new Array[Int](10) 赋值:arr(0) = xxx Array[ ...
- Scala中的数组和集合操作
package test /* 1.在scala集合中,Iterable是共同的Trait,Iterable要求继承者实现一些共同的方法,例如元素的遍历 * 2.Array是scala基础的数据结构, ...
- scala中的数组的转换操作
1.共有两种操作 转换成一种新的数组 2.yield转换 3.函数式编程转换
- Programming In Scala笔记-第十七章、Scala中的集合类型
本章主要介绍Scala中的集合类型,主要包括:Array, ListBuffer, Arraybuffer, Set, Map和Tuple. 一.序列 序列类型的对象中包含多个按顺序排列好的元素,可以 ...
- Scala学习(三)----数组相关操作
数组相关操作 摘要: 本篇主要学习如何在Scala中操作数组.Java和C++程序员通常会选用数组或近似的结构(比如数组列表或向量)来收集一组元素.在Scala中,我们的选择更多,不过现在我们先假定不 ...
- Scala中Zip相关的函数
在Scala中存在好几个Zip相关的函数,比如zip,zipAll,zipped 以及zipWithIndex等等.我们在代码中也经常看到这样的函数,这篇文章主要介绍一下这些函数的区别以及使用. 1. ...
- [原创]Scala学习:数组的基本操作,数组进阶操作,多维数组
1.Scala中提供了一种数据结构-数组,其中存储相同类型的元素的固定大小的连续集合.数组用于存储数据的集合,但它往往是更加有用认为数组作为相同类型的变量的集合 2 声明数组变量: 要使用的程序的数组 ...
- Scala中的If判断&While&For循环
If 判断: object TestScalaIf { def main(args: Array[String]): Unit = { // val resutlt = judge1(-100) // ...
随机推荐
- jquery获取第几个元素的方法总结
使用jquery时经常会遇到,选择器选择一组元素后,需要在这组元素中找到第几个元素. jquery中使用eq()方法找到第几个元素或第N个元素,jquery中eq()的使用如下: eq() 选择器选取 ...
- LA 3644 易爆物 并查集
题目链接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show ...
- pthread_join和pthread_detach的用法(转)
一:关于join join join是三种同步线程的方式之一.另外两种分别是互斥锁(mutex)和条件变量(condition variable). 调用pthread_join()将阻塞自己,一直到 ...
- CDH hive的安装
tar zxvf 解压包 配置环境变量 export HIVE_HOME=/usr/local/soft/hiveexport PATH=$PATH:$JAVA_HOME/bin:$HADOOP_HO ...
- timus 1210 Kind Spirits(最短路)(动态规划)
Kind Spirits Time limit: 1.0 secondMemory limit: 64 MB Ivanushka the Fool lives at the planet of 0-l ...
- 配置Apache将自己的电脑做服务器使局域网内的电脑访问自己的主机
很多的朋友都想把自己的电脑打造为服务器使别人能够访问.比如说你自己写了一网站,只能自己通过localhost访问或127.0.0.1访问.但是怎么让别人的电脑也能访问呢?来看看自己写的网站.现在我来讲 ...
- 黑马程序员——JAVA基础之单列设计模式
------- android培训.java培训.期待与您交流! ---------- 单列设计模式是面试中的一个常考的点,所谓单例模式就是说对象在内存中只能存在一个.如果有其他变量是该类对象,那么他 ...
- 释放Linux系统预留的硬盘空间【转】
http://www.cnblogs.com/ggjucheng/archive/2012/10/07/2714294.html 前言 大多数文件系统都会保留一部分空间留作紧急情况时用(比如硬盘空间满 ...
- C#中调用C++的dll的参数为指针类型的导出函数(包括二级指针的情况)
严格来说这篇文章算不上C++范围的,不过还是挂了点边,还是在自己的blog中记录一下吧. C++中使用指针是家常便饭了,也非常的好用,这也是我之所以喜欢C++的原因之一.但是在C#中就强调托管的概念了 ...
- ABBYY FineReader出现错误和警告提示的解决办法
识别结果的质量取决于多种因素,这些因素包括原始文档的质量.结构布局和文档导出参数等.在使用ABBYY FineReader Pro for Mac OCR文字识别软件处理文档的各个阶段,应用程序均可能 ...