scala 数组Array

本文介绍了Scala中数组(Array)的基本操作,包括数组的创建、初始化、修改等过程,并展示了数组元素的访问与修改方法。通过示例说明了Scala数组的特性及其在实际应用中的灵活性。

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


scala> //-------------array--------------------

scala> val arr=new Array[Int](5)          --arr的index不可变,值可以变
arr: Array[Int] = Array(0, 0, 0, 0, 0)

scala> arr(3)
res0: Int = 0

scala> arr(2)=8

scala> arr
res2: Array[Int] = Array(0, 0, 8, 0, 0)

scala> var arr1=Array("Spark","Scala")        --这句等于内部调用了apply方法,apply就是工厂方法构造器
arr1: Array[String] = Array(Spark, Scala)

scala> var arr1=Array.apply("Spark","Scala")
arr1: Array[String] = Array(Spark, Scala)

scala> arr1
res3: Array[String] = Array(Spark, Scala)

scala> Array                
res4: Array.type = scala.Array$@e7f2ccd                --Array本身是不可变的

scala> arr1(2)="Hadoop"      --给第三个元素赋值出错
java.lang.ArrayIndexOutOfBoundsException: 2
        at .<init>(<console>:9)
        at .<clinit>(<console>)
        at .<init>(<console>:7)
        at .<clinit>(<console>)
        at $print(<console>)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at scala.tools.nsc.interpreter.IMain$ReadEvalPrint.call(IMain.scala:734)
        at scala.tools.nsc.interpreter.IMain$Request.loadAndRun(IMain.scala:983)
        at scala.tools.nsc.interpreter.IMain.loadAndRunReq$1(IMain.scala:573)
        at scala.tools.nsc.interpreter.IMain.interpret(IMain.scala:604)
        at scala.tools.nsc.interpreter.IMain.interpret(IMain.scala:568)
        at scala.tools.nsc.interpreter.ILoop.reallyInterpret$1(ILoop.scala:760)
        at scala.tools.nsc.interpreter.ILoop.interpretStartingWith(ILoop.scala:805)
        at scala.tools.nsc.interpreter.ILoop.command(ILoop.scala:717)
        at scala.tools.nsc.interpreter.ILoop.processLine$1(ILoop.scala:581)
        at scala.tools.nsc.interpreter.ILoop.innerLoop$1(ILoop.scala:588)
        at scala.tools.nsc.interpreter.ILoop.loop(ILoop.scala:591)
        at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply$mcZ$sp(ILoop.scala:882)
        at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:837)
        at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:837)
        at scala.tools.nsc.util.ScalaClassLoader$.savingContextLoader(ScalaClassLoader.scala:135)
        at scala.tools.nsc.interpreter.ILoop.process(ILoop.scala:837)
        at scala.tools.nsc.MainGenericRunner.runTarget$1(MainGenericRunner.scala:83)
        at scala.tools.nsc.MainGenericRunner.process(MainGenericRunner.scala:96)
        at scala.tools.nsc.MainGenericRunner$.main(MainGenericRunner.scala:105)
        at scala.tools.nsc.MainGenericRunner.main(MainGenericRunner.scala)


### Scala 中 `Array` 的 `apply` 方法 在 Scala 中,`Array` 是一种固定大小的序列集合。通过 `apply` 方法可以从数组中获取特定索引位置上的元素[^1]。 #### 获取单个元素 下面展示如何利用 `apply` 方法访问数组中的某个具体元素: ```scala val numbers = Array(10, 20, 30, 40, 50) println(s"The element at index 2 is ${numbers.apply(2)}") // 输出 The element at index 2 is 30 ``` 这段代码创建了一个名为 `numbers` 的整型数组,并使用 `apply` 方法读取索引为 2 处的值(即第三个元素),结果为 30。 #### 结合其他函数一起工作 除了单独用于检索数据外,`apply` 还经常与其他高阶函数配合使用来处理复杂逻辑: ```scala val data = Array("apple", "banana", "orange") // 找到长度大于等于6的第一个字符串并打印出来 data.find(_.length >= 6).foreach(word => println(s"Found word with length>=6: $word")) ``` 在这个例子中虽然没有直接看到 `apply` 函数的应用,但实际上当调用像 `find()` 或者 `foreach()` 等方法时内部都会涉及到对各个元素的操作——这背后就依赖于 `apply` 来完成实际的数据存取操作。 #### 创建新数组 值得注意的是,在某些情况下也可以借助 `apply` 构造新的数组实例。不过这种方式更常见于可变集合类型如 `Buffer` 或者不可变类型的工厂方法里;对于基本类型的 `Array` 则通常采用字面量形式定义或通过 `ofDim` 工厂方法初始化。 ```scala import scala.collection.mutable.ArrayBuffer val buffer = ArrayBuffer[Int]() buffer += (1 to 5): _* // 添加一系列数值至缓冲区 println(buffer.toArray) // 将其转换成普通数组输出 [1,2,3,4,5] ``` 尽管上述示例主要展示了关于 `ArrayBuffer` 的应用,但是从中可以看出不同容器间相互转化的过程中同样离不开 `apply` 的作用机制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值