Scala中可变和不可变之图文解析
var 和 val 简单理解:var声明的是变量 , 因此是可变的 , val声明的是值 , 因此是不可变的 。本质上声明当前对象的存储地址引用是否能够改变指向其他地址 。
Scala中集合分为可变和不可变集合 , 即mutable和immutable , 它们表示的是在内存中存储内容是否可以改变 。 可变集合可以在原内存中的内容上修改 , 添加 , 移除;但不可变集合永远都不能修改开始开辟的内存空间中的内容 , 但是可以模拟添加 , 移除和更新操作 , 然后返回新的集合(原集合不发生任何改变) 。
下面以Queue队列进行代码演示 。
Queue队列是FIFO(先进先出) , Queue分可变和不可变(immutable queue and mutable queue) 。
完整代码如下:
package valvar
import scala.collection.immutable._
import scala.collection.mutable
object MyQueue {
【Scala中可变和不可变之图文解析】 def main(args: Array[String]): Unit = {
val queue = Queue[Int]()
// 当Queue属于不可变集合包时 , 对它进行改变内容的操作会返回一个新的对象
// queue1是新返回的队列对象
val queue1 = queue.enqueue(1)
// 当前 Queue 属于不可变集合 , 所以上一步入队操作其实是模拟操作 , queue并没有元素入队
// 返回的 queue1 是新生成的对象
println(s"queue: ${queue}")
println(s"queue1: ${queue1}")
// 当Queue属于可变集合包时 , 能在原内容上修改 , 对它进行改变内容的操作不会返回新的对象
// queue3是Unit类型的空值 , 说明没有返回新的对象
val queue2=new mutable.Queue[Int]()
val queue3=queue2.enqueue(10)
println(s"queue2: ${queue2}")
println(s"queue3: ${queue3}")
// 测试var 和 val 的区别
var queue5 = Queue[Int]()
// 把 queue5 指向的地址改为指向 queue1 。 如果使用 val 声明 queue5 , 那么这个修改就不能完成
queue5 = queue1
// 因为 queue5 指向为不可变集合 , 所以这一步不能修改到原内容的值
val queue6 = queue5.enqueue(5)
println(s"queue5: ${queue5}")
println(s"queue1: ${queue1}")
println(s"queue6: ${queue6}")
}
}
输出结果:
文章插图
变量和内存空间示意图:
文章插图
推荐阅读
- 联想推出现代“上网本”NEC Lavie Mini 可变身为游戏机
- 骁龙888首次实现可变分辨率渲染 创造沉浸式游戏体验
- 显示器|LG 将在CES 2021上展示一款可变身曲面屏OLED游戏显示器
- 一加8T概念机发布 mmWave雷达系统加持手机可变色
- Scala隐式转换入门实践
- 在连接USB-C充电器后Pixel 5可变身无线充电面板
- 独特分体可变形设计,CHERRY MC 8.1游戏鼠标上手体验
- IDEA中添加Scala语言的Maven flink模板