开发者社区> 端吉> 正文

java与scala数组及集合基本操作对比

简介: 这篇博客介绍了scala的数组 + 可变数组的基本使用,及其与java数组的区别(博客中代码参照 快学scala) scala数组基本操作 def main(args: Array[String]): Unit = { //new一个大小不变...
+关注继续查看

这篇博客介绍了scala的数组 + 可变数组的基本使用,及其与java数组的区别(博客中代码参照 快学scala)

scala数组基本操作

def main(args: Array[String]): Unit = {

    //new一个大小不变的数组
    val nums = new Array[Int](10) //会被初始化为0

    val s = Array("hello", "world") //使用两个字符串初始化数组(记住,这里不需要new)

    s(0) = "good bye" //使用()来访问数组

}

scala数组底层实现就是java数组,上述底层是java.lang.String[]

对应java代码

public static void main(String[] args) {
    int[] nums = new int[10];

    String[] s = new String[]{"hello", "world"};

    s[0] = "goodbye";
}

scala可变数组ArrayBuffer

def main(args: Array[String]): Unit = {
    val b = ArrayBuffer[Int]() //初始化
    //或者
    //    val b = new ArrayBuffer[Int]

    b += 1 //添加一个元素
    b += (1, 2, 3, 4, 5) //添加多个元素在末尾

    println(s"b:$b") //b:ArrayBuffer(1, 1, 2, 3, 4, 5)

    b ++= Array(8, 1, 34) //一次添加一个数组,注意这里是数组
    println(s"b:$b") //b:ArrayBuffer(1, 1, 2, 3, 4, 5, 8, 1, 34)

    b.trimEnd(3) //移除最后三个元素
    println(s"b:$b") //b:ArrayBuffer(1, 1, 2, 3, 4, 5)
}

java 相应 ArrayList操作

public static void main(String[] args) {
    List<Integer> list = new ArrayList<>();
    list.add(1);

    List<Integer> list2 = new ArrayList<>();
    list2.add(1);
    list2.add(2);
    list2.add(3);
    list2.add(4);
    list2.add(5);
    list.addAll(list2);
    //java一次要添加1,2,3,4,5就麻烦很多了
    // 当然使用guava的Lists.newArrayList看起来代码会简单些
    // 或者使用下面的Arrays.asList也会简单些,最主要的原因是直接构造一个含有多个数字的list原生的java支持的不好

    System.out.println(list); //[1, 1, 2, 3, 4, 5]

    list.addAll(Arrays.asList(1, 2, 3, 4, 5));
    System.out.println(list); //[1, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5]

    //java没有提供原生的,移除最后5个元素的函数

    list.add(1,6); //List一次只能添加一个元素
    System.out.println(list); //[1, 6, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5]

    list.remove(1);
    System.out.println(list); //[1, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5]

    //list也不支持,移除第index上的连续n个数字

    Object[] array = list.toArray();//转数组
    Arrays.asList(array); //转list
}

scala 的数组遍历

def main(args: Array[String]): Unit = {
  val a = Array(1, 2, 3, 4, 5)
  for (i <- 0 until a.length) {
    println(s"i:$i value:${a(i)}")
  }

  println("-----------")

  //遍历隔一个
  for (i <- 0 until a.length by 2) {
    println(s"i:$i value:${a(i)}")
  }

  println("-----------")

  //倒着遍历
  for (i <- 0 until a.length reverse) {
    println(s"i:$i value:${a(i)}")
  }

  println("-----------")

  //如果不需要index
  for (ele <- a) {
    println(s"value:${ele}")
  }
}

java数组的遍历

public static void main(String[] args) {
    int[] a = new int[]{1, 2, 3, 4, 5};

    for (int i = 0; i < a.length; i++) {
        System.out.println("index:" + i + ",value:" + a[i]);
    }

    System.out.println("-----------------");

    //遍历隔着2
    for (int i = 0; i < a.length; i += 2) {
        System.out.println("index:" + i + ",value:" + a[i]);
    }

    System.out.println("-----------------");

    //倒着遍历
    for (int i = a.length - 1; i >= 0; i--) {
        System.out.println("index:" + i + ",value:" + a[i]);
    }

    System.out.println("-----------------");

    //不关心index
    for (int value : a) {
        System.out.println("value:" + value);
    }
}

java数组和scala数组遍历差不多,需要提的一点是,scala的遍历方式比较统一,无论是Array还是ArrayBuffer,java的list和array就不大一样(array使用[]取值,list使用get()取值,而scala都是())

对比下就知道,scala提供的可变数组比java的更加强大易用

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Java运行Scala代码
Java运行Scala代码
34 0
Java 的 List 转 scala的Buffer | 学习笔记
快速学习 Java 的 List 转 scala 的 Buffer
100 0
Java 模拟 Scala 的运行机制|学习笔记
快速学习 Java 模拟 Scala 的运行机制。
33 0
IDEA 新建Maven项目同时支持Java和Scala两种语言
IDEA 新建Maven项目同时支持Java和Scala两种语言
118 0
Scala/Java - Redis 连接检测与重试
项目实现中需要连接 redis,为了防止因网络抖动或其他原因造成的客户端连接失败,一般需要增加重试机制判断 client 是否连接成功,之前写了一版重连代码发现有 bug,借此机会看下代码 bug 以及如何更好的重连 redis。...
165 0
Maven - Scala/Java 项目添加自己的 jar 包
一.引言 scala / java 项目引用非官方依赖 jar 包时,需要自定义并打入最终的 jar 包,经过试验以下方案可以实现。 二.添加 jar 包到 maven 库 ???? 第三方自定义 jar 包可以添加到本地 maven 库中,随后即可 mvn package 打入到最终的项目 jar 包中,该方法最方便。创建 install.sh 文件,jar_path 为第三方自定义 jar 包在设备的位置,groupId、artifactId 和 版本号 version 自己定义,执行脚本后
136 0
Scala / Java - 采用 MD5 加盐 实现 id 均匀分组
大量 id 场景下经常需要通过 id 进行 AB Test,最常见的就是使用尾号 hash 进行分组,但是由于 id 生成规则以及其他因素,按照尾号分组往往会造成 id 不匀,从而导致 AB Test 效果受影响,所以下文采用 md5 加盐 Hash 的方式,得到更均匀的分组与 AB Test 效果。......
221 0
Flink - 读取 Parquet 文件 By Scala / Java
parquet 文件常见与 Flink、Spark、Hive、Streamin、MapReduce 等大数据场景,通过列式存储和元数据存储的方式实现了高效的数据存储与检索,下面介绍 Flink 场景下如何读取 Parquet。
558 0
Scala/Java - shuffle 数组详解
本地使用 spark paralize 数组 rdd 时需要构造一个随机数组,分别使用 java.util 和 scala.util 实现,下面记录下不同的 shuffle 方法以及踩到的坑。
97 0
IDEA实现Java与Scala代码混合开发
IDEA实现Java与Scala代码混合开发
335 0
+关注
端吉
蘑菇街后端开发工程师
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
Java工程师必读手册
立即下载
Java应用提速(速度与激情)
立即下载
Java单元测试实战
立即下载