Scala中的var和val定义有什么区别?为什么这两种定义都需要?为什么你会选择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是最终值,即不能设置。在java中考虑final。
区别在于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,那么该数据结构因此是不可变的,因为它的状态不能改变。
Val表示不可变,var表示可变
您可以将val视为Java编程语言的final key world或c++语言的const key world。
虽然很多人已经回答了Val和var之间的区别。 但是需要注意的一点是val并不完全像final关键字。
我们可以用递归改变val的值,但我们永远不能改变final的值。Final比Val更恒定。
def factorial(num: Int): Int = {
if(num == 0) 1
else factorial(num - 1) * num
}
方法参数默认为val,并且在每次调用时都会更改值。
推荐文章
- 将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对象和对象的区别