回答:
scala> println (Nil == List())
true
scala> println (Nil eq List())
true
scala> println (Nil equals List())
true
scala> System.identityHashCode(Nil)
374527572
scala> System.identityHashCode(List())
374527572
Nilはより慣用的であり、ほとんどの場合に優先できます。質問?
List[A]()
(ではないNil
)必要はありませんか?例- ここでアキュムレータとしてscala> Map(1 -> "hello", 2 -> "world").foldLeft(List[String]())( (acc, el) => acc :+ el._2) res1: List[String] = List(hello, world)
使用Nil
しても機能しません。
Map(1 -> "hello", 2 -> "world").foldLeft(Nil: List[String])( _ :+ _._2)
ユーザー未知のは、両方の実行時の値を示しているNil
とList()
同じです。ただし、それらの静的タイプは以下ではありません。
scala> val x = List()
x: List[Nothing] = List()
scala> val y = Nil
y: scala.collection.immutable.Nil.type = List()
scala> def cmpTypes[A, B](a: A, b: B)(implicit ev: A =:= B = null) = if (ev eq null) false else true
cmpTypes: [A, B](a: A, b: B)(implicit ev: =:=[A,B])Boolean
scala> cmpTypes(x, y)
res0: Boolean = false
scala> cmpTypes(x, x)
res1: Boolean = true
scala> cmpTypes(y, y)
res2: Boolean = true
これは、フォールドのアキュムレータなど、タイプを推論するために使用される場合に特に重要です。
scala> List(1, 2, 3).foldLeft(List[Int]())((x, y) => y :: x)
res6: List[Int] = List(3, 2, 1)
scala> List(1, 2, 3).foldLeft(Nil)((x, y) => y :: x)
<console>:10: error: type mismatch;
found : List[Int]
required: scala.collection.immutable.Nil.type
List(1, 2, 3).foldLeft(Nil)((x, y) => y :: x)
^
y :: x
動作します。問題は、それが返す型が期待される型ではないことです。それは返すList[Int]
型が期待される一方でいずれかである、List[Nothing]
またはNil.type
(私はかつて、多分後者だと思います)。
未知のユーザーの答えが示すように、それらは同じオブジェクトです。
素晴らしくて短いので、慣用的にはNilをお勧めします。ただし例外があります。何らかの理由で明示的な型が必要な場合
List[Foo]()
より良い
Nil : List[Foo]
List.empty[Foo]
3番目の選択肢もあります。
Nil
がより慣用的であると言うことができます。