Scala中的var和val定义有什么区别?为什么这两种定义都需要?为什么你会选择val而不是var,反之亦然?
当前回答
Val表示不可变,var表示可变。
完整的讨论。
其他回答
虽然很多人已经回答了Val和var之间的区别。 但是需要注意的一点是val并不完全像final关键字。
我们可以用递归改变val的值,但我们永远不能改变final的值。Final比Val更恒定。
def factorial(num: Int): Int = {
if(num == 0) 1
else factorial(num - 1) * num
}
方法参数默认为val,并且在每次调用时都会更改值。
在javascript方面,它与
val -> const 是 -> 是
val表示不可变,var表示可变
解释一下,“val表示值,var表示变量”。
A distinction that happens to be extremely important in computing (because those two concepts define the very essence of what programming is all about), and that OO has managed to blur almost completely, because in OO, the only axiom is that "everything is an object". And that as a consequence, lots of programmers these days tend not to understand/appreciate/recognize, because they have been brainwashed into "thinking the OO way" exclusively. Often leading to variable/mutable objects being used like everywhere, when value/immutable objects might/would often have been better.
从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)
区别在于var可以被重新赋值,而val则不能。可变性,或其他任何实际分配的东西,是一个次要问题:
import collection.immutable
import collection.mutable
var m = immutable.Set("London", "Paris")
m = immutable.Set("New York") //Reassignment - I have change the "value" at m.
而:
val n = immutable.Set("London", "Paris")
n = immutable.Set("New York") //Will not compile as n is a val.
因此:
val n = mutable.Set("London", "Paris")
n = mutable.Set("New York") //Will not compile, even though the type of n is mutable.
如果您正在构建一个数据结构,并且它的所有字段都是val,那么该数据结构因此是不可变的,因为它的状态不能改变。
推荐文章
- 什么时候我应该在Scala中选择向量?
- 在Scala中,foldLeft和reducleft的区别
- 好的scalaz介绍
- Akka Kill vs Stop vs Poison Pill?
- 如何开始与Akka流?
- Scala 2.8 breakOut
- 如何克隆一个案例类实例,只改变一个字段在Scala?
- ':_* '(冒号下划线*)在Scala中有什么作用?
- 定义一个函数时,“def”和“val”有什么区别
- 在Scala中获取列表中的项目?
- case对象和对象的区别
- Scala中的Case对象与枚举
- 任务不可序列化:java.io.NotSerializableException,当只对类而不是对象调用闭包外部的函数时
- 在Scala中将一个元素附加到列表的末尾
- 在Scala中按名称调用vs按值调用,需要澄清