Scala_数组、以及与java数组的互转

博客介绍了Array的申明方式,包括一维、多维和变长数组的申明。还阐述了Java数组与Scala数组缓冲的隐式转换问题,指出在Scala代码调用JDK API时,直接传入类型不匹配会出错,可使用scala.collection.JavaConverters进行显式转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1、Array的申明

2、Java数组与Scala数组缓冲的隐式转换


1、Array的申明

val arr:Array[T] = new Array[T](Length)    
val arr: = new Array[T](Length)              
val arr: = Array[Int](1, 2, 3)         
       
多维数组,数据中的元素还是数组
var arr = Array.ofDim[Int](2,2)

变长数组,可以通过+=或append方法追加元素或元组或通过++=追加数组
import scala.collection.mutable.ArrayBuffer
val arr = new ArrayBuffer[Int]()
val arr = ArrayBuffer[Int](1, 2, 3)

2、Java数组与Scala数组缓冲的隐式转换

Scala代码中,直接调用JDK(Java)的API,比如调用一个Java类的方法,势必可能会传入Java类型的list;Scala中构造出来的list,其实是ArrayBuffer;你直接把Scala的ArrayBuffer传入Java接收ArrayList的方法,肯定不行。

使用 scala.collection.JavaConverters 与Java集合交互。它有一系列的隐式转换,添加了asJava和asScala的转换方法。使用它们这些方法确保转换是显式的

import scala.collection.JavaConverters._
import scala.collection.mutable.ArrayBuffer


val arr = ArrayBuffer[Int](1, 2, 3)
val list:java.util.List[Int]=arr .asJava
val buffer: scala.collection.mutable.Buffer[Int] = list.asScala

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值