Scala数组,定长数组和变长数组,增强for循环,until用法,数组转换,数组常用算法,数组其它操作

2024-04-19 18:32

本文主要是介绍Scala数组,定长数组和变长数组,增强for循环,until用法,数组转换,数组常用算法,数组其它操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 数组

1.1. 定长数组和变长数组

package cn.toto.scala//可变数组的长度时需要引入这个包
import scala.collection.mutable.ArrayBuffer/*** Created by toto on 2017/6/27.*/
object ArrayDemo {def main(args: Array[String]): Unit = {//初始化一个长度为8的定长数组,其所有元素均为0val arr1 = new Array[Int](8)//直接打印定长数组,内容为数组的的hashcode值println(arr1)//将数组转换成数组缓冲,就可以看到原数组中的内容了。//toBuffer会将数组转换成数组缓冲println(arr1.toBuffer)//注意:如果没有new,相当于调用了数组的apply方法,直接为数组赋值//赋初始一个长度为1的定长数组val arr2 = Array[Int](10)println(arr2.toBuffer)//定义一个长度为3的定长数组var arr3 = Array("hadoop","storm","spark")//使用()来访问元素println(arr3(2))//////////////////////////////////////////////////////////////////变长数组(数组缓冲)//如果想使用数组缓冲,需要导入import scala.collection.mutable.ArrayBuffer包val ab = ArrayBuffer[Int]()//向数组缓冲的尾部追加一个元素//+=尾部追加元素ab += 1println(ab)//追加多个元素ab += (2,3,4,5)println(ab)//追加一个数组++=ab ++= Array(6,7)println(ab)//追加一个数组缓冲ab ++= ArrayBuffer(8,9)//打印数组缓冲abprintln(ab)//在数组某个位置插入元素用inseret,其中第一个参数是其实位置,后面两个参数是要添加进入的值ab.insert(0,-1,0)println(ab)//删除数组某个位置的元素用remove,下面的含义是从0这个位置开始,删除2个元素ab.remove(0,2)println(ab)}
}

运行后的结果如下:

[I@4563e9ab
ArrayBuffer(0, 0, 0, 0, 0, 0, 0, 0)
ArrayBuffer(10)
spark
ArrayBuffer(1)
ArrayBuffer(1, 2, 3, 4, 5)
ArrayBuffer(1, 2, 3, 4, 5, 6, 7)
ArrayBuffer(1, 2, 3, 4, 5, 6, 7, 8, 9)
ArrayBuffer(-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9)
ArrayBuffer(1, 2, 3, 4, 5, 6, 7, 8, 9)

1.2. 遍历数组

1.增强for循环
2.好用的until会生成脚标,0 until 10 包含0不包含10
这里写图片描述

package cn.toto.scala/*** Created by toto on 2017/6/28.*/
object ForArrayDemo {def main(args: Array[String]): Unit = {//初始化一个数组val arr = Array(1,2,3,4,4,5,6,7,8)//增强for循环for(i <- arr)print(i + " ")println("")//好用的until会生成一个Range//reverse是将前面生成的Range反转for(i <- (0 until arr.length).reverse)print(arr(i) + " ")}
}

运行后的结果如下:

1 2 3 4 4 5 6 7 8 
8 7 6 5 4 4 3 2 1

1.3. 数组转换

yield关键字将原始的数组进行转换会产生一个新的数组,原始的数组不变
这里写图片描述

package cn.toto.scala/*** Created by toto on 2017/6/28.*/
object ArrayYieldDemo {def main(args: Array[String]): Unit = {//定义一个数组val arr = Array(1,2,3,4,5,6,7,8,9)//将偶数取出乘以10后再生成一个新的数组val res = for(e <- arr if e % 2 == 1) yield e * 10println(res.toBuffer)//更高级的写法,用着更爽//filter是过滤,接收一个返回值为boolean的函数//map相当于将数组中的每一个元素取出来,应用传进去的函数val r = arr.filter(_ % 2 == 0).map(_ * 10)println(r.toBuffer)}
}

运行后的结果如下:

ArrayBuffer(10, 30, 50, 70, 90)
ArrayBuffer(20, 40, 60, 80)

1.4. 数组常用算法

在Scala中,数组上的某些方法对数组进行相应的操作非常方便!
这里写图片描述
其它数组操作:

scala> var arr = Array(1,6,5,4,7,9,2,25,22,11)
arr: Array[Int] = Array(1, 6, 5, 4, 7, 9, 2, 25, 22, 11)升序排序
scala> arr.sorted
res13: Array[Int] = Array(1, 2, 4, 5, 6, 7, 9, 11, 22, 25)降序
scala> arr.sorted.reverse
res14: Array[Int] = Array(25, 22, 11, 9, 7, 6, 5, 4, 2, 1)scala> arr.sortWith(_>_)
res15: Array[Int] = Array(25, 22, 11, 9, 7, 6, 5, 4, 2, 1)上面的等价下面的,相当于是降序:
scala> arr.sortWith((x,y) => x > y)
res16: Array[Int] = Array(25, 22, 11, 9, 7, 6, 5, 4, 2, 1)下面是升序
scala> arr.sortWith((x,y) => x < y)
res17: Array[Int] = Array(1, 2, 4, 5, 6, 7, 9, 11, 22, 25)scala> val a = Array("hadoop",1.0,2)
a: Array[Any] = Array(hadoop, 1.0, 2)scala> a(1).asInstanceOf[Double]
res20: Double = 1.0scala> val arr1 = new Array[Int](8)
arr1: Array[Int] = Array(0, 0, 0, 0, 0, 0, 0, 0)scala> arr1(1) = 6scala> arr1
res26: Array[Int] = Array(0, 6, 0, 0, 0, 0, 0, 0)定义变长数组,需要引入包:
scala> import scala.collection.mutable.ArrayBuffer
import scala.collection.mutable.ArrayBufferscala> val ab = new ArrayBuffer[Int]()
ab: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer()scala> ab += 1
res27: ab.type = ArrayBuffer(1)scala> ab
res28: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(1)scala> ab += 2
res30: ab.type = ArrayBuffer(1, 2)scala> ab += (2,3,4,5)
res31: ab.type = ArrayBuffer(1, 2, 2, 3, 4, 5)scala>

这篇关于Scala数组,定长数组和变长数组,增强for循环,until用法,数组转换,数组常用算法,数组其它操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918271

相关文章

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.