Scala中的var和val定义有什么区别?为什么这两种定义都需要?为什么你会选择val而不是var,反之亦然?
当前回答
在javascript方面,它与
val -> const 是 -> 是
其他回答
Val表示不可变,var表示可变。
完整的讨论。
Val表示最终值,不能重新赋值
而Var可以在以后重新分配。
Val是最终值,即不能设置。在java中考虑final。
简单来说:
var = 变量
Val =变量+ final
从c++的角度思考,
val x: T
是否类似于指向非常量数据的常量指针
T* const x;
而
var x: T
类似于指向非常量数据的非常量指针吗
T* x;
偏好val而不是var增加了代码库的不可变性,这有助于它的正确性、并发性和可理解性。
要理解常量指针指向非常量数据的含义,请考虑以下Scala代码片段:
val m = scala.collection.mutable.Map(1 -> "picard")
m // res0: scala.collection.mutable.Map[Int,String] = HashMap(1 -> picard)
这里的“指针”val m是常量,所以我们不能将它重新赋值为指向其他东西
m = n // error: reassignment to val
但是我们确实可以改变m指向的非常数数据本身
m.put(2, "worf")
m // res1: scala.collection.mutable.Map[Int,String] = HashMap(1 -> picard, 2 -> worf)
推荐文章
- 将JAR文件添加到Spark作业- Spark -submit
- Scala中的JavaConverters和JavaConversions有什么区别?
- 在Scala 2.8中<:<、<%<和=:=是什么意思?它们被记录在哪里?
- Scala vs Python的Spark性能
- 什么时候我应该在Scala中选择向量?
- 在Scala中,foldLeft和reducleft的区别
- 好的scalaz介绍
- Akka Kill vs Stop vs Poison Pill?
- 如何开始与Akka流?
- Scala 2.8 breakOut
- 如何克隆一个案例类实例,只改变一个字段在Scala?
- ':_* '(冒号下划线*)在Scala中有什么作用?
- 定义一个函数时,“def”和“val”有什么区别
- 在Scala中获取列表中的项目?
- case对象和对象的区别