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的更加强大易用

目录
相关文章
|
16小时前
|
存储 算法 Java
Java数组与for语句
Java数组与for语句
6 0
|
1天前
|
存储 Java
【JAVA学习之路 | 进阶篇】集合框架概述
【JAVA学习之路 | 进阶篇】集合框架概述
|
2天前
|
存储 搜索推荐 Java
【java】数组的定义与使用
//第二种方法:for each for(int[]tmp:array){//左边是数组的每个元素,右边是数组名
8 1
|
2天前
|
存储 Java 容器
Java一分钟之-高级集合框架:LinkedList与TreeSet
【5月更文挑战第21天】本文对比了Java集合框架中的LinkedList和TreeSet。LinkedList是双向链表,实现List接口,适合中间插入删除,但遍历效率低;TreeSet基于红黑树,实现Set接口,保证元素有序且无重复,插入删除速度较LinkedList慢,但查找排序快。选择时应根据具体需求考虑操作频率和排序需求。
14 1
|
4天前
|
并行计算 Java API
Java 8中的接口默认方法和静态方法以及并行数组
【5月更文挑战第19天】Java 8引入了许多新特性,其中包括接口的默认方法和静态方法,以及并行数组的能力。这些特性增强了Java的面向对象编程模型和数组处理能力。让我们深入了解它们的概念和实践。
22 2
|
4天前
|
安全 Java 容器
Java一分钟之-并发编程:线程安全的集合类
【5月更文挑战第19天】Java提供线程安全集合类以解决并发环境中的数据一致性问题。例如,Vector是线程安全但效率低;可以使用Collections.synchronizedXxx将ArrayList或HashMap同步;ConcurrentHashMap是高效线程安全的映射;CopyOnWriteArrayList和CopyOnWriteArraySet适合读多写少场景;LinkedBlockingQueue是生产者-消费者模型中的线程安全队列。注意,过度同步可能影响性能,应尽量减少共享状态并利用并发工具类。
18 2
|
5天前
|
算法 搜索推荐 Java
滚雪球学Java(33):数组算法大揭秘:应用案例实战分享
【5月更文挑战第8天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
32 8
滚雪球学Java(33):数组算法大揭秘:应用案例实战分享
|
5天前
|
安全 Java 容器
Java一分钟之-高级集合框架:并发集合(Collections.synchronizedXXX)
【5月更文挑战第18天】Java集合框架的`Collections.synchronizedXXX`方法可将普通集合转为线程安全,但使用时需注意常见问题和易错点。错误的同步范围(仅同步单个操作而非迭代)可能导致并发修改异常;错误地同步整个集合类可能引起死锁;并发遍历和修改集合需使用`Iterator`避免`ConcurrentModificationException`。示例代码展示了正确使用同步集合的方法。在复杂并发场景下,推荐使用`java.util.concurrent`包中的并发集合以提高性能。
18 3
|
5天前
|
Java 开发者
Java一分钟之-高级集合框架:优先队列(PriorityQueue)
【5月更文挑战第18天】`PriorityQueue`是Java集合框架中的无界优先队列,基于堆数据结构实现,保证队头元素总是最小。常见操作包括`add(E e)`、`offer(E e)`、`poll()`和`peek()`。元素排序遵循自然排序或自定义`Comparator`。常见问题包括错误的排序逻辑、可变对象排序属性修改和混淆`poll()`与`peek()`。示例展示了自然排序和使用`Comparator`的排序方式。正确理解和使用`PriorityQueue`能提升应用性能。
39 6
|
5天前
|
存储 Java
Java一分钟之-高级集合框架:Queue与Deque接口
【5月更文挑战第18天】本文探讨Java集合框架中的`Queue`和`Deque`接口,两者都是元素序列的数据结构。`Queue`遵循FIFO原则,主要操作有`add/remove/element/peek`,空队列操作会抛出`NoSuchElementException`。`Deque`扩展`Queue`,支持首尾插入删除,同样需注意空`Deque`操作。理解并正确使用这两个接口,结合具体需求选择合适数据结构,能提升代码效率和可维护性。
30 4