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) // ...
随机推荐
- python 批量爬取代理ip
import urllib.request import re import time import random def getResponse(url): req = urllib.request ...
- [HAOI2012]音量调节
题目描述 一个吉他手准备参加一场演出.他不喜欢在演出时始终使用同一个音量,所以他决定每一首歌之前他都需要改变一次音量.在演出开始之前,他已经做好一个列表,里面写着每首歌开始之前他想要改变的音量是多少. ...
- LeetCode() Valid Anagram 有问题!!!
为什么第一个通过,第二个不行呢? class Solution { public: bool isAnagram(string s, string t) { if(s.size() != t.size ...
- 利用Web服务器网络打洞
好了有些标题党了.这里想说的是:某些网络,除了http 80服务,其它端口的服务都被限制了,这个时候可以用http web服务器来进行代理转发. 以Apache为例,支持ssh登录到其它服务器的配置如 ...
- HTTP 状态消息
1xx: 信息 消息: 描述: 100 Continue 服务器仅接收到部分请求,但是一旦服务器并没有拒绝该请求,客户端应该继续发送其余的请求. 101 Switching Protocols 服务器 ...
- Twsited异步网络框架
Twisted是一个事件驱动的网络框架,其中包含了诸多功能,例如:网络协议.线程.数据库管理.网络操作.电子邮件等. Twisted介绍:http://blog.csdn.net/hanhuili/a ...
- IL-rewriting profiler
https://blogs.msdn.microsoft.com/davbr/2007/03/06/creating-an-il-rewriting-profiler/ https://blogs.m ...
- ob_start()失效与phpunit的非正常结束
在ob_clean();或ob_get_clean()之前有return或致命错误,从而结束了程序,会导致ob_start失效, 这和phpunit的非正常结束
- Unity3D 几个基本动画(控制物体移动、旋转、缩放)
Transform基本移动函数: 1.指定方向移动: //移动速度 float TranslateSpeed = 10f; //Vector3.forward 表示"向前" tra ...
- 安装postgreSQL出现configure:error:readline library not found解决方法
要安装 readline , readline-dev 开发包,要么使用 --without-readline 选项关闭 readline 功能. #yum install readline; #yu ...