Dеar Scala,In che modo una funzione anonima "caso" funziona davvero in Scala?
scala> val f1: ((Int, Int)) => Int = { case (a, b) => a + b }
f1: ((Int, Int)) => Int = <function1>
scala> val f2: (Int, Int) => Int = { case (a, b) => a + b }
f2: (Int, Int) => Int = <function2>
eh ?!
scala> f1(1, 2)
res2: Int = 3
Ok ...
scala> def takesIntInt2Int(fun: (Int, Int) => Int) = fun(100, 200)
takesIntInt2Int: (fun: (Int, Int) => Int)Int
scala> def takesTuple2Int(fun: ((Int, Int)) => Int) = fun(100, 200)
takesTuple2Int: (fun: ((Int, Int)) => Int)Int
scala> takesIntInt2Int(f2)
res4: Int = 300
scala> takesIntInt2Int(f1)
<console>:10: error: type mismatch;
found : ((Int, Int)) => Int
required: (Int, Int) => Int
takesIntInt2Int(f1)
^
scala> takesTuple2Int(f1)
res6: Int = 300
scala> takesTuple2Int(f2)
<console>:10: error: type mismatch;
found : (Int, Int) => Int
required: ((Int, Int)) => Int
takesTuple2Int(f2)
destro. E ora, guarda questo!
scala> takesTuple2Int { case (a, b, c) => a + b + c }
<console>:9: error: constructor cannot be instantiated to expected type;
found : (T1, T2, T3)
required: (Int, Int)
takesTuple2Int { case (a, b, c) => a + b + c }
^
scala> takesIntInt2Int { case (a, b, c) => a + b + c }
<console>:9: error: constructor cannot be instantiated to expected type;
found : (T1, T2, T3)
required: (Int, Int)
takesIntInt2Int { case (a, b, c) => a + b + c }
Come, srsly? o_O Entrambi risultano nell'errore required: (Int, Int)
.
Perché utilizzare quindi case
in tali funzioni anonime?
Sarebbe bello poter fare tutto questo senza usare la parola chiave 'case'. Perché la differenza nella sintassi per Function e PartialFunction, dal punto di vista dello sviluppatore normale? –
@ MichałRus Ad essere sincero, questo mi ha sempre infastidito un po '. Haskell e Clojure hanno sintassi molto più semplici per esprimere la corrispondenza del modello direttamente sui parametri di una funzione. – wingedsubmariner