スタックオーバーフロー:
こんにちは、みんな。
varargs を持つ部分的に適用された関数を定義したいと思います。
確認するために、いくつかの関数、つまりFunctions._を用意しました。func 以外の関数には varargs 引数があります。
可変引数を使用して部分的に適用された関数を定義して呼び出す方法は? (たとえば、可変引数を指定した gunc1。)
Java バージョン "1.7.0_07" Scala コード ランナー バージョン 2.9.1.final
object Functions {
def func(x: Int, y: Int) = x + y
def gunc(x: Int*) = x.sum
def hunc(x: Int, y: Int*) = x + y.sum
def iunc(x: Int)(y: Int*) = x + y.sum // curried
def junk(x: String, y: Int*) = x + y.sum
}
object PartiallyApplied extends App {
import Functions._
val func0 = func(1, _: Int) // I can.
println("result: " + func0(2))
val gunc0 = gunc(1, _: Int) // I can invoke if I specify the varargs.size. But gunc0 no longer has varargs...
println("result: " + gunc0(2))
// val gunc1 = gunc(1, _: Int*) => compile error: ')' expected but identifier found.
// val gunc1 = gunc(1, _: Seq[Int]) => compile error: type mismatch | found: Seq[Int] | required: Int
val gunc1 = gunc(1, _: Int) // I can invoke if I specify the varargs.size. But gunc1 no longer has varargs...
println("result: " + gunc1(2))
// val hunc0 = hunc(1)_ => compile error: _ must follow method; cannot follow Int
// val hunc0 = hunc(1, _: Int*) => compile error: ')' expected but identifier found.
// val hunc0 = hunc(1, _: Seq[Int]) => compile error: type mismatch | found: Seq[Int] | required: Int
val hunc0 = hunc(1, _: Int) // I can invoke if I specify the varargs.size. But hunc0 no longer has varargs...
println("result: " + hunc0(2))
// println("result: " + hunc0(2, 3)) => compile error: too many arguments for method apply: (v1: Int)Int in trait Function1
// println("result: " + hunc0((2, 3): _*)) => compile error: type mismatch | found: (Int, Int) | required: Seq[Int]
// println("result: " + hunc0(Seq(2, 3))) => compile error: type mismatch | found: Seq[Int] | required: Int
// println("result: " + hunc0(Seq(2, 3): _*)) => compile error: no `: _*' annotation allowed here (such annotations are only allowed in arguments to *-parameters)
val hunc1 = hunc(1, _: Int, _: Int) // I can invoke if I specify the varargs.size. But hunc1 no longer has varargs...
println("result: " + hunc1(2, 3))
val hunc2 = hunc(1, _: Int, _: Int, _:Int) // I can invoke if I specify the varargs.size. But hunc2 no longer has varargs...
val hunc3 = hunc2(2, _: Int, _: Int)
val hunc4 = hunc3(3, _: Int)
println("result: " + hunc4(4))
println("result: " + hunc5(2, 3))
// val iunc0 = iunc(1)(_: Int*) => compile error: ')' expected but identifier found.
// val iunc0 = iunc(1)(_: Seq[Int]) => compile error: type mismatch | found: Seq[Int] | required: Int
val iunc0 = iunc(1)(_: Int)
println("result: " + iunc0(2))
val iunc1 = iunc(1)(_: Int, _: Int)
println("result: " + iunc1(2, 3))
}
object NotPartiallyApplied extends App {
import Functions._
println("result: " + gunc(1))
println("result: " + gunc(1, 2, 3))
println("result: " + gunc(Seq(1, 2, 3): _*))
println("result: " + hunc(1))
println("result: " + hunc(1, 2, 3))
println("result: " + hunc(1, Seq(2, 3): _*))
println("result: " + iunc(1)(2, 3))
println("result: " + iunc(1)(Seq(2, 3): _*))
println("result: " + junk("x"))
println("result: " + junk("x", 2, 3))
println("result: " + junk("x", Seq(2, 3): _*))
}
[レックス・カーのコメント後に編集]
以下の guncN のような部分的に適用された関数が必要です。
val guncN = gunc(1, _: Int*)
println("result: " + guncN(2)) // => 3
println("result: " + guncN(2, 3)) // => 6
println("result: " + guncN(2, 3, 4, 5, 100)) // => 115
しかし、それは scalac によって禁止されています。
guncN は (2)、(2, 3)、(2, 3, 4, 5, 100) が与えられるたびに評価されるべきだと思います。以下の guncM は必要ありません。
val guncM = guncN(2, _: Int*)
println("result: " + guncM(3, 4)) // => 10